MySQL not in不等于找不到null的数据

在开发过程中用了
select * from table where status not in(1,2,3)
但是结果不展示列位null的数据产生了严重的bug

在使用MySQL的NOT IN语句时,如果找不到NULL值,可能是因为NULL值在比较中具有特殊性质。NULL值不等于任何其他值,包括它自己。因此,使用NOT IN语句时,如果列表中包含NULL值,则查询不会返回任何结果。

解决此问题的方法之一是使用IS NULL或IS NOT NULL运算符来检查NULL值。以下是一个示例查询:

SELECT * FROM table_name WHERE column_name IS NULL;

或者:

SELECT * FROM table_name WHERE column_name IS NOT NULL;

这样可以确保NULL值被正确地包含或排除在结果中。

据上:
最后改成了 select * from table where status not in(1,2,3) or status is null 可以获取所有数据

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

兰博lamb

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值