作了一个以下的小厕所,若是我须要获得返回是 d,f 那我须要用那组语句呢?sql
A:spa
;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:code
;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:blog
;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 的执行顺序有关的。io
一般咱们看select 的执行顺序的时候,可能会忽略这2个不经常使用的链接谓词致使误判。这里作一个实验就能够发现,其实 Except(Intersect 同理) 的查询优先级是和 union 或者union all 是同级的。class
因此遵循从左到右的顺序,若是不用括号改变执行顺序,从上面的例子,将会返回 CA Except CB -> Union CB -> Except CA 的执行结果。也就是一个容易忽略的位置。select
由于比较少用,因此我也躺枪了。在此分享一波,但愿你们不要踩坑。nio
PS查询
1 select 执行顺序的地址 :https://docs.microsoft.com/zh-cn/sql/t-sql/queries/select-transact-sql分享
2 Except 和 Intersect 都是返回交叉以后不重复的结果的,这个须要特别注意