mysql不等于判断时,空值过滤问题
Posted 经典鸡翅
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql不等于判断时,空值过滤问题相关的知识,希望对你有一定的参考价值。
产生根源
比如我们有三条数据,对应的列名是delete_flag,对应的数据是‘normal’,‘delete’,null。
此时我们查所有不等于delete的记录,我们期望的是两条记录 normal和null。我们书写如下sql。
select * from a where delete_flag != 'delete'
发现查询出来的结果只是一条,这是因为mysql的空值过滤机制。
解决
1、进行一下非null判断
select * from a where IFNULL(delete_flag,'') != 'delete'
2、将null空值也加入条件
select * from a where delete_flag != 'delete' or delete_flag is null
以上是关于mysql不等于判断时,空值过滤问题的主要内容,如果未能解决你的问题,请参考以下文章