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

被折叠的 条评论
为什么被折叠?



