MySql Int 类型和 varchar类型进行比较。

今天遇到个比较奇葩的问题,简单讲就是在Mysql中进行查询的时候 在Where语句中使用的int类型的字段和Varchar类型的字段进行对比。

例如:我这有一张表:

MySql Int 类型和 varchar类型进行比较。

表中的数据如下:

MySql Int 类型和 varchar类型进行比较。

当我进行查询的时候:

奇葩的问题出现了:

MySql Int 类型和 varchar类型进行比较。

按道理讲,234是不等于234dgdgdgdgdgd的,可为什么Mysql会在这里认为他们是相等的?

把ID的类型转换为Varchar以后,该问题就不存在了。

不知道Mysql内部的机制是怎样的,但应该是把234dgdgdgdgdgd开始截取的数字转换成int类型然后进行的比较。

该类型的问题告诉我们必须要注意在数据库中的比较要确保字段的类型一致。

上一篇:Centos下安装PHP ldap扩展


下一篇:CSS---伪类与伪元素的区别