发布网友 发布时间:2022-05-03 02:44
共8个回答
懂视网 时间:2022-05-03 07:05
比如我们有三条数据,对应的列名是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 期望 记录 产生
热心网友 时间:2022-05-03 04:13
使用 IS NOT NULL 可以去除空值热心网友 时间:2022-05-03 05:31
先用数据库函数进行null值转换再比较:热心网友 时间:2022-05-03 07:06
还有很多搭配方式,1.where热心网友 时间:2022-05-03 08:57
sqlserver:热心网友 时间:2022-05-03 11:05
SELECT * from 表热心网友 时间:2022-05-03 13:30
SELECT * from 表热心网友 时间:2022-05-03 16:11
SELECT * from 表