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

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

比如:select * from tb where str=0;会查到str为'0','0abc','abc'等数据。不符合查询的条件啊。

原因如下:

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

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

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

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

相关推荐
©️2020 CSDN 皮肤主题: 像素格子 设计师:CSDN官方博客 返回首页