码迷,mamicode.com
首页 > 数据库 > 详细

mysql不等于判断时,空值过滤问题

时间:2019-11-18 09:38:06      阅读:374      评论:0      收藏:0      [点我收藏+]

标签:let   问题   where   null   空值   code   期望   记录   产生   

产生根源

比如我们有三条数据,对应的列名是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不等于判断时,空值过滤问题

标签:let   问题   where   null   空值   code   期望   记录   产生   

原文地址:https://www.cnblogs.com/jichi/p/11880135.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!