首页 > 数据库技术 > 详细

Mysql Not in有null值查询的问题

时间:2016-01-12 21:35:11      阅读:196      评论:0      收藏:0      [点我收藏+]

今天发现Mysql的not in使用的一个问题,大致是:

select * from A where id not in (select fid from B).

发现查询结果无论如何都是0条记录。后来发现B里面返回的查询结果集有一条NULL值,查了资料才知道mysql 的not in里面如果有一个NULL值,将返回0条记录。

要解决这个问题需要把 select fid from B 变成

select fid from B where B.fid is not null

这个问题在其他的数据库里也会有,是因为 not in的处理有问题。再具体详细说明一下,如下:

select * from A where id not in (1,2,null )

那么就没有记录返回,因为里面有null值,当用id和null比较的时候,会返回false,所以一条记录都不会返回,所以要改成下面就可以了:

select * from A where id not in (select bid from B where bid  is not null ) 

Mysql Not in有null值查询的问题

原文:http://www.cnblogs.com/longshiyVip/p/5125546.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!