使用 Except 和 Intersect

作了一個以下的小廁所,若是我須要獲得返回是 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 都是返回交叉以後不重複的結果的,這個須要特別注意

相關文章
相關標籤/搜索