mysql int类型where条件查询时 自动转换问题

mysql int类型where条件查询时 自动转换问题

表数据

正常查询

  • content存的是varchar类型,查的时候where content是字符类型,此时没有数据。

异常查询

  • content存的是varchar类型,查的时候where content是数字类型,此时查询出本来不匹配的数据。
  • where content 数字类型的时候,会把数据表中字符类型转成数字类型,再与where content匹配,而字符10001-xxx-xx 转成数字为 10001,这与php类似,所以匹配上了。

小结

  • 查询的时候,尽量让数据类型与表字段数据类型保持一致
posted @ 2020-09-07 09:17  pine007  阅读(1055)  评论(0编辑  收藏  举报