sql INOT IN踩的坑

文章讨论了在SQL查询中,当子查询包含NULL值时,NOTIN查询可能失效的问题。作者给出了一个示例并推荐使用NOTEXISTS来确保正确返回结果,即使子查询包含NULL值。
摘要由CSDN通过智能技术生成

标题当子查询中存在 NULL 值时,使用 NOT IN 查询时会出现问题。因为 NULL 值既不等于也不不等于任何值,所以无法确定它是否属于 NOT IN 子句中的结果集。因此,如果子查询的结果集中包含 NULL 值,NOT IN 查询将返回空结果。

create table test1 (id1 int)
create table test2 (id2 int)

insert into test1 (id1) values (1),(2),(3)
insert into test2 (id2) values (1),(2)

使用此语句能查出3
select * from test1 where id1 not in (select id2 from test2);

当往test2表插入一条null数据的时候
insert into test2 (id2) values (NULL);

在执行上面语句返回的是NULL而不是3
select * from test1 where id1 not in (select id2 from test2);

如果要返回3请使用下面语句
SELECT * FROM test1
WHERE NOT EXISTS (SELECT * FROM test2 WHERE test1.id1 = test2.id2);
  • 11
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值