Mysql中关于0值判断的坑

木来 木来

最近遇到一个Mysql返回多值的问题,最后发现是mysql过滤条件中0值判断的问题。

简练问题如下:

    有个INT字段a,默认值为0,程序传入的判断条件是 a = 'abacd'。

    传入的是一个字符串,结果a=0的所有数据都返回了。

原因:

    mysql会在逻辑判断时,如果是整型判断,但是传入的是字符串,如果字符串不是数字,则字符串会被转换为0。所以,

这段代码实际判断的条件是 a = 0。

解决方式:

    mysql中的逻辑判断,判断值的传入,应该与字段类型一致,整型判断整型,字符串判断字符串。如果避免不了,跨类型的判断,那么就需要根据业务逻辑,进行调整,避免掉入这个坑。

问题引申:

    如果字段a是否varchar类型,值为0,那么判断时应该用 a='0'判断,而不是 a = 0 判断,原因与上面的原因一致,字符串会被转换为0,结果最终判断的是 0 = 0。

3 条评论
木来
木来 (作者) 回复 .
厉害了
.
jdbctype
.
留言成功 下面留言加载出来了 上面多少条评论的值 没改变 要手动刷新页面