今天在项目里发现了个好玩的BUG,来记录下。
首先:表数据是这样的(项目里的表就不展示了,随意弄个临时表)
由于a的默认值为空,同事就写了这样的sql
select * from t1 where a =0
和这样的sql
select * from t1 where a>0
————————————————–
于是问题就出现了:
第一个sql结果如下:
没错,出来了2条记录,接下来看另一个sql结果
反而只出来一条结果。。。。
至于原因嘛,很明显是a类型引起的,
由于a是字符串,where a=0 的成立条件就成了a 的值是’0′,或者是非数字开头的字符串
where a >0 出来的数据的原因在于 字符串a最左边的数字是6
具体字符串做比较的规则可以参考https://dev.mysql.com/doc/refman/5.7/en/type-conversion.html
解决办法:把0改为’0′
所以数据库的字段类型务必查看仔细,避免发生隐式类型转换不走索引和造BUG
————————————————
版权声明:本文为CSDN博主「牙疼疼疼疼疼」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/New_CJ/article/details/105869966