mysql not in null的坑

本文记录了在MySQL中使用not in查询遇到的问题,当查询涉及的字段存在NULL值时,查询结果可能为空。原因是MySQL中NULL值不参与任何比较运算,导致条件不成立。理解这一特性对于避免类似错误至关重要。解决方案是在查询时考虑NULL值的情况。

最近在mysql中做a表与b表之间的not in查询的时候无法查询出任何数据,实际是存在a表的部分记录在b表中不存在,执行的sql类似如下:

select *
from a
where name2 not in (select name from b)

最后发现是b表的name字段存在null值的情况,花了点时间研究了下神奇的null,明白了其中的原因,在此记录下防止其他人再踩坑。

1.首先mysql的官方文档里面描述null值为“不存在的值”,任何算术运算符与null比较都为null。

同时说了在mysql中0或者null布尔运算为false,其他值为true;

2.那回到上面说的not in 中存在null情况,x NOT IN (S)  可以表示为x!=S1 && x!=s2 ... && x!=sn,当所有“&&”运算的判断都为true的时候才返回该条记录,只要有一个false则不返回,那假设S1为null,则x!=S1返回false,整个运算返回false,那么整条记录不返回。

参考文档:

mysql官方文档

stackoverflow

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值