mysql不等于判断时,空值过滤问题
发布日期:2021-05-09 03:55:35 浏览次数:19 分类:精选文章

本文共 353 字,大约阅读时间需要 1 分钟。

产生根源

比如我们有三条数据,对应的列名是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
上一篇:css实现文字渐变
下一篇:SpringBoot中maven打包,启动报没有主清单属性

发表评论

最新留言

哈哈,博客排版真的漂亮呢~
[***.90.31.176]2025年05月06日 11时51分48秒