SQL SERVER中EXCEPT/INTERSECT,CASE/ISNULL/COALESCE

來源:互聯網
上載者:User

SQL SERVER中EXCEPT/INTERSECT,CASE/ISNULL/COALESCE
EXCEPT 和 INTERSECT

一般解釋:比較兩個查詢的結果,返回非重複值。

EXCEPT 從左查詢中返回右查詢沒有找到的所有非重複值。

INTERSECT 返回 左右兩邊的兩個查詢都包含的所有非重複值。

以下是將使用 EXCEPT 或 INTERSECT 的兩個查詢的結果集組合起來的基本規則:

  • 所有查詢中的列數和列的順序必須相同。

  • 資料類型必須相容。

假設test表中testid包含1,1,2,3,4,4;test2表中id包含1,2,3,4,5,6

select testid from testintersectselect id from test2

結果只有1,2,3,4。

select id from test2exceptselect testid from test


結果只有5,6.


對比CASE, ISNULL, COALESCE

ISNULL和COALESCE大體上相同,相當於CASE 語句:

CASE

   WHEN (expression1 IS NOT NULL) THEN expression1

   WHEN (expression2 IS NOT NULL) THEN expression2

   ...

   ELSE expressionN

END

ISNULLCOALESCE還是 不同的。

SELECT ISNULL(NULL,NULL)返回NULL。

SELECT COALESCE(NULL,NULL)則報錯:至少有一個參數不可為空。

ISNULL只能有兩個參數,如ISNULL(1,NULL),而COALESCE則可以有多個參數,如COALESCE(NULL,3,NULL,1)。

ISNULL最終返回值類型跟第一個參數類型相同。如果兩個參數的類型不同並最終返回值等於第二個參數,則會把第二個參數進行隱式轉換為第一個參數的類型再返回。

如,

DECLARE @Field1 char(4), @Field2 char(50)SET @Field2 = 'LeeWhoee University'SELECT ISNULL(@Field1, @Field2)--返回 'LeeW'SELECT COALESCE(@Field1, @Field2)--返回 'LeeWhoee University'



相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.