使用 Except 和 Intersect
程序员文章站
2022-03-30 12:26:20
做了一个如下的小厕所,如果我需要得到返回是 d,f 那我需要用那组语句呢? A: B: C: 实际情况执行一下就知道,其实BC 的语句都可以执行。而A的执行情况就是只返回了 d。这个其实是跟select 的执行顺序有关的。 通常我们看select 的执行顺序的时候,可能会忽略这2个不常用的连接谓词导 ......
做了一个如下的小厕所,如果我需要得到返回是 d,f 那我需要用那组语句呢?
A:
;WITH CA AS( SELECT * FROM (VALUES('a'),('b'),('c'),('d'))a (A)) ,CB AS ( SELECT * FROM (VALUES('a'),('b'),('c'),('f'))a (A) ) SELECT * FROM CA EXCEPT SELECT * FROM CB UNION SELECT * FROM CB EXCEPT SELECT * FROM CA
B:
;WITH CA AS( SELECT * FROM (VALUES('a'),('b'),('c'),('d'))a (A)) ,CB AS ( SELECT * FROM (VALUES('a'),('b'),('c'),('f'))a (A) ) SELECT * FROM CA EXCEPT SELECT * FROM CB UNION (SELECT * FROM CB EXCEPT SELECT * FROM CA)
C:
;WITH CA AS( SELECT * FROM (VALUES('a'),('b'),('c'),('d'))a (A)) ,CB AS ( SELECT * FROM (VALUES('a'),('b'),('c'),('f'))a (A) ) (SELECT * FROM CA EXCEPT SELECT * FROM CB) UNION (SELECT * FROM CB EXCEPT SELECT * FROM CA)
实际情况执行一下就知道,其实BC 的语句都可以执行。而A的执行情况就是只返回了 d。这个其实是跟select 的执行顺序有关的。
通常我们看select 的执行顺序的时候,可能会忽略这2个不常用的连接谓词导致误判。这里做一个实验就可以发现,其实 Except(Intersect 同理) 的查询优先级是和 union 或者union all 是同级的。
所以遵循从左到右的顺序,如果不用括号改变执行顺序,从上面的例子,将会返回 CA Except CB -> Union CB -> Except CA 的执行结果。也就是一个容易忽略的位置。
因为比较少用,所以我也躺枪了。在此分享一波,希望大家不要踩坑。
PS
1 select 执行顺序的地址 :https://docs.microsoft.com/zh-cn/sql/t-sql/queries/select-transact-sql
2 Except 和 Intersect 都是返回交叉之后不重复的结果的,这个需要特别注意
上一篇: C++ bitset的实现教程
推荐阅读
-
tfn2k使用方法和对策(1)
-
AI钢笔工具使用技巧和方法介绍
-
sqlserver安装和简单的使用
-
配置Nginx多核CPU,worker_cpu_affinity使用方法和范例 affinity ds2 2 affinity 28 affinity
-
使用REG注册表文件添加、修改或删除注册表键值和子项介绍
-
最新数据显示:新冠疫情危机期间Zoom和微软云使用量飙升
-
springboot整合shiro多验证登录功能的实现(账号密码登录和使用手机验证码登录)
-
Oracle密码文件的使用和维护第1/3页
-
Android使用AudioRecord和AudioTrack完成音频的采集和播放以及使用MediaCodec完成硬编和硬解
-
js防抖函数和节流函数使用场景和实现区别示例分析