溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

SQL Server中的集合運(yùn)算: UNION, EXCEPT和INTERSECT的案例分析

發(fā)布時(shí)間:2020-08-10 10:00:13 來源:億速云 閱讀:248 作者:小新 欄目:開發(fā)技術(shù)

這篇文章給大家分享的是有關(guān)SQL Server中的集合運(yùn)算: UNION, EXCEPT和INTERSECT的案例分析的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考。一起跟隨小編過來看看吧。

SQL Server中的集合運(yùn)算包括UNION(合并),EXCEPT(差集)和INTERSECT(相交)三種。

集合運(yùn)算的基本使用

1.UNION(合并兩個(gè)查詢結(jié)果集,隱式DINSTINCT,刪除重復(fù)行)

--合并兩個(gè)提取表/派生表(derived table), 返回結(jié)果為:[a,b,c,d,e]
SELECT FC FROM (VALUES('a'),('b'),('c'),('e')) Table1 (FC)
UNION
SELECT FC FROM (VALUES('a'),('b'),('c'),('d')) Table2 (FC)

2.UNION ALL(簡單合并兩個(gè)查詢結(jié)果集,不刪除重復(fù)行)

--提取表/派生表(derived table)可以是多列,列名、順序可以不同,但列數(shù)必須相同
SELECT * FROM (VALUES('a','Anna'),('b','Bob'),('c','Cassie'),('e','Elina')) Table1 (FC, Name)
UNION ALL
SELECT * FROM (VALUES('a','Anna'),('b','Bob'),('c','Cassie'),('d','David')) Table2 (FC, Name)

3.EXCEPT(返回出現(xiàn)在第一個(gè)結(jié)果集但不出現(xiàn)在第二個(gè)結(jié)果集中的所有行)

--返回結(jié)果為:[e]
SELECT FC FROM (VALUES('a'),('b'),('c'),('e')) Table1 (FC)
EXCEPT
SELECT FC FROM (VALUES('a'),('b'),('c'),('d')) Table2 (FC)

4.INTERSECT(返回第一個(gè)查詢結(jié)果集和第二個(gè)查詢結(jié)果集共有的部分)

--返回結(jié)果為:[a,b,c]
SELECT FC FROM (VALUES('a'),('b'),('c'),('e')) Table1 (FC)
INTERSECT
SELECT FC FROM (VALUES('a'),('b'),('c'),('d')) Table2 (FC)

集合運(yùn)算的使用場景

1.使用UNION代替Where子句中的OR,查詢速度更快

--使用Where子句 + OR
SELECT name, population, area FROM world WHERE area > 3000000 OR population > 25000000

--使用UNION
SELECT name, population, area FROM world WHERE area > 3000000
UNION
SELECT name, population, area FROM world WHERE population > 25000000

2.使用EXCEPTINTERSECT, 過濾出列表中不存在/存在于數(shù)據(jù)庫中的項(xiàng)

假設(shè)存在表Customers, 數(shù)據(jù)如下表所示

cust_idcust_namecust_addresscust_citycust_statecust_countrycust_contactcust_email
1000000001Village Toys200 Maple LaneDetroitMIUSAJohn Smithsales@villagetoys.com
1000000002Kids Place333 South Lake DriveColumbusOHUSAMichelle GreenNULL
1000000003Fun4All1 Sunny PlaceMuncieINUSAJim Jonesjjones@fun4all.com
1000000004Fun4All829 Riverside DrivePhoenixAZUSADenise L. Stephensdstephens@fun4all.com
1000000005The Toy Store4545 53rd StreetChicagoILUSAKim HowardNULL
--過濾出列表中不存在于數(shù)據(jù)庫中的項(xiàng)
--返回結(jié)果為['1000000006','1000000007']
SELECT [Id] AS [cust_id] FROM
(
VALUES('1000000004'),('1000000005'),('1000000006'),('1000000007')
) dt ([Id])
EXCEPT
SELECT [cust_id] FROM [Customers]

--過濾出列表中存在于數(shù)據(jù)庫中的項(xiàng)
--返回結(jié)果為['1000000004','1000000005']
SELECT [Id] AS [cust_id] FROM
(
VALUES('1000000004'),('1000000005'),('1000000006'),('1000000007')
) dt ([Id])
INTERSECT
SELECT [cust_id] FROM [Customers]
--對(duì)于SQLServer 2008以前的版本
SELECT [Id] AS [cust_id] FROM
(
  SELECT '1000000004' UNION ALL
  SELECT '1000000005' UNION ALL
  SELECT '1000000006' UNION ALL
  SELECT '1000000007'
) dt ([Id])
INTERSECT
--EXCEPT
SELECT [cust_id] FROM [Customers]
//使用C#動(dòng)態(tài)生成SQL語句
var list = new List<string>(){"1000000004","1000000005","1000000006","1000000007"};
string sqlQuery = string.Format($@"
  SELECT [Id] AS [cust_id] FROM
  (
    VALUES('{string.Join("'),('", list)}')
  ) dt ([Id]
  INTERSECT
  --EXCEPT
  SELECT [cust_id] FROM [Customers]"
);

感謝各位的閱讀!關(guān)于SQL Server中的集合運(yùn)算: UNION, EXCEPT和INTERSECT的案例分析就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI