相关文章推荐
近视的桔子  ·  SELECT 下拉框 重复点击选项 ...·  1 月前    · 
飘逸的炒饭  ·  如何使用并发控制CCL规则_云数据库 ...·  1 月前    · 
想表白的面包  ·  什么是KV/KKV查询_智能开放搜索 ...·  1 月前    · 
稳重的冰淇淋  ·  深入解析Oracle数据库ORA-01427 ...·  1 月前    · 
茫然的黑框眼镜  ·  MISSING_AGGREGATION ...·  4 周前    · 
八块腹肌的冲锋衣  ·  如何使用matplotlib根据右侧y轴设置 ...·  1 年前    · 
重感情的板凳  ·  可视化节点编辑器(Node Editor) ...·  1 年前    · 
飞翔的打火机  ·  Shader学习(8)各种坐标空间的定义和变 ...·  2 年前    · 
Code  ›  sql 在not in 子查询有null值情况下经常出现的陷阱开发者社区
select
https://cloud.tencent.com/developer/article/1343532
深情的便当
1 年前
跟着阿笨一起玩NET
0 篇文章

sql 在not in 子查询有null值情况下经常出现的陷阱

前往专栏
腾讯云
开发者社区
文档 意见反馈 控制台
首页
学习
活动
专区
工具
TVP
最新优惠活动
文章/答案/技术大牛
发布
首页
学习
活动
专区
工具
TVP 最新优惠活动
返回腾讯云官网
跟着阿笨一起玩NET
首页
学习
活动
专区
工具
TVP 最新优惠活动
返回腾讯云官网
社区首页 > 专栏 > 跟着阿笨一起玩NET > sql 在not in 子查询有null值情况下经常出现的陷阱

sql 在not in 子查询有null值情况下经常出现的陷阱

作者头像
跟着阿笨一起玩NET
发布 于 2018-09-19 16:44:33
2.3K 0
发布 于 2018-09-19 16:44:33
举报

如果下:Table_A表和Table_B表,要求查询出在Table_A表中不在Table_B表中的记录。

CREATE TABLE [dbo].[Table_A](
 [ID] [nchar](10) NULL,
 [Name] [nchar](10) NULL
) ON [PRIMARY]
ID          Name
001        张三        
002        李四        
003        王五              
CREATE TABLE [dbo].[Table_B](
 [ID] [nchar](10) NULL,
 [Name] [nchar](10) NULL
) ON [PRIMARY]
ID        Name
NULL     张三        
002       李四        
NULL     王五 

很容大家第一时间相当的写法是:

SELECT  *
FROM    dbo.Table_A AS a
WHERE   a.ID NOT IN ( SELECT    b.ID
                      FROM      dbo.Table_B AS b)

然而查询出来并没有达到预期的

ID    Name 001  张三        003  王五

原因很简单:由于NULL不能进行如何的“操作”

–如果null参与算术运算,则该算术表达式的值为null。(例如:+,-,*,/ 加减乘除)

–如果null参与比较运算,则结果可视为false。(例如:>=,<=,<>  大于,小于,不等于)

–如果null参与聚集运算,则聚集函数都置为null。除count(*)之外。

--如果在not in子查询中有null值的时候,则不会返回数据。  (最简单的解释请参考下面的评论说明)

--正确写法                      
SELECT  *
FROM    dbo.Table_A AS a
WHERE   a.ID NOT IN ( SELECT    b.ID
                      FROM      dbo.Table_B AS b
                      WHERE     b.ID IS NOT NULL ) --排除NULL值参与运算符比较
--建议修改为关联查询方法                                            
--正确写法1             
SELECT  *
FROM    dbo.Table_A AS a
WHERE   NOT EXISTS ( SELECT *
                     FROM   dbo.Table_B AS b
 
推荐文章
近视的桔子  ·  SELECT 下拉框 重复点击选项 change事件无法再次触发的问题
1 月前
飘逸的炒饭  ·  如何使用并发控制CCL规则_云数据库 RDS(RDS)-阿里云帮助中心
1 月前
想表白的面包  ·  什么是KV/KKV查询_智能开放搜索 OpenSearch(Open Search)-阿里云帮助中心
1 月前
稳重的冰淇淋  ·  深入解析Oracle数据库ORA-01427错误:单行子查询返回多行的问题与解决办法
1 月前
茫然的黑框眼镜  ·  MISSING_AGGREGATION 错误条件 - Azure Databricks | Microsoft Learn
4 周前
八块腹肌的冲锋衣  ·  如何使用matplotlib根据右侧y轴设置水平网格线?
1 年前
重感情的板凳  ·  可视化节点编辑器(Node Editor) - Pulaski - 博客园
1 年前
飞翔的打火机  ·  Shader学习(8)各种坐标空间的定义和变换演示 - 知乎
2 年前
今天看啥   ·   Py中国   ·   codingpro   ·   小百科   ·   link之家   ·   卧龙AI搜索
删除内容请联系邮箱 2879853325@qq.com
Code - 代码工具平台
© 2024 ~ 沪ICP备11025650号