MySql数据库,对varchar类型字段str进行where str=0条件查询时,查询结果是什么

在用MySQL查询数据的时候,遇到了一个奇怪的问题。用一个varchar类型的字符串str,作为条件与0比较时,会查str不为0的数据。

比如:SELECT id, idnumber from hr_student where idnumber = 0;会查到idnumber 为'0','身份证',''等数据。不符合查询的条件啊。

原因如下:

MySql在比较varchar类型和0的时候,会把varchar类型转换成数字0

所以用idnumber =0作为条件时,会把以0开头的字符串和普通字符串都转换成0。(比如:0abc,0,abc,身份证号码)

只排除一些以非0开头的字符串。(比如:1abc)

同理,查询str=1的数据,也会排除开头非1的字符串。

原文地址:https://www.cnblogs.com/xs-yqz/p/6378876.html