sql INOT IN踩的坑

标题当子查询中存在 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);

相关推荐

  1. sql INOT IN

    2024-02-02 13:30:02       32 阅读
  2. 实现快速排序所

    2024-02-02 13:30:02       17 阅读
  3. kotlin gradle

    2024-02-02 13:30:02       10 阅读
  4. mySQL记录

    2024-02-02 13:30:02       44 阅读
  5. Pinia 记录

    2024-02-02 13:30:02       35 阅读
  6. FollowYourPose 安装

    2024-02-02 13:30:02       29 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-02-02 13:30:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-02 13:30:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-02 13:30:02       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-02 13:30:02       20 阅读

热门阅读

  1. Linux(ubuntu) -- 安装后调配

    2024-02-02 13:30:02       31 阅读
  2. CCF-CSP 202206-1 归一化处理

    2024-02-02 13:30:02       29 阅读
  3. IDEA常用快捷健

    2024-02-02 13:30:02       26 阅读
  4. 点亮第一个LED实验

    2024-02-02 13:30:02       35 阅读
  5. 【极简】Pytorch中的register_buffer()

    2024-02-02 13:30:02       31 阅读
  6. MySQL运维实战(5.4) MySQL元数据乱码

    2024-02-02 13:30:02       39 阅读
  7. 【springBoot】统一功能处理

    2024-02-02 13:30:02       32 阅读
  8. InDesign Server-功能介绍-IDML 文件-ID插件

    2024-02-02 13:30:02       28 阅读