栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 数据库 > MySQL > MsSql

SQL Server中的集合运算: UNIOn, EXCEPT和INTERSECT示例代码详解

MsSql 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

SQL Server中的集合运算: UNIOn, EXCEPT和INTERSECT示例代码详解

SQL Server中的集合运算包括UNIOn(合并),EXCEPT(差集)和INTERSECT(相交)三种。

集合运算的基本使用

1.UNIOn(合并两个查询结果集,隐式DINSTINCT,删除重复行)

--合并两个提取表/派生表(derived table), 返回结果为:[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(简单合并两个查询结果集,不删除重复行)

--提取表/派生表(derived table)可以是多列,列名、顺序可以不同,但列数必须相同
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(返回出现在第一个结果集但不出现在第二个结果集中的所有行)

--返回结果为:[e]
SELECt FC FROM (VALUES('a'),('b'),('c'),('e')) Table1 (FC)
EXCEPT
SELECt FC FROM (VALUES('a'),('b'),('c'),('d')) Table2 (FC)

4.INTERSECT(返回第一个查询结果集和第二个查询结果集共有的部分)

--返回结果为:[a,b,c]
SELECt FC FROM (VALUES('a'),('b'),('c'),('e')) Table1 (FC)
INTERSECT
SELECt FC FROM (VALUES('a'),('b'),('c'),('d')) Table2 (FC)

集合运算的使用场景

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.使用EXCEPT和INTERSECT, 过滤出列表中不存在/存在于数据库中的项

假设存在表Customers, 数据如下表所示

cust_id cust_name cust_address cust_city cust_state cust_country cust_contact cust_email
1000000001 Village Toys 200 Maple Lane Detroit MI USA John Smith sales@villagetoys.com
1000000002 Kids Place 333 South Lake Drive Columbus OH USA Michelle Green NULL
1000000003 Fun4All 1 Sunny Place Muncie IN USA Jim Jones jjones@fun4all.com
1000000004 Fun4All 829 Riverside Drive Phoenix AZ USA Denise L. Stephens dstephens@fun4all.com
1000000005 The Toy Store 4545 53rd Street Chicago IL USA Kim Howard NULL

--过滤出列表中不存在于数据库中的项
--返回结果为['1000000006','1000000007']
SELECt [Id] AS [cust_id] FROM
(
VALUES('1000000004'),('1000000005'),('1000000006'),('1000000007')
) dt ([Id])
EXCEPT
SELECt [cust_id] FROM [Customers]

--过滤出列表中存在于数据库中的项
--返回结果为['1000000004','1000000005']
SELECt [Id] AS [cust_id] FROM
(
VALUES('1000000004'),('1000000005'),('1000000006'),('1000000007')
) dt ([Id])
INTERSECT
SELECt [cust_id] FROM [Customers]
--对于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#动态生成SQL语句
var list = new List(){"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]"
);

更多参考

Set Operators - EXCEPT and INTERSECT

Set Operators - UNIOn

到此这篇关于SQL Server中的集合运算: UNIOn, EXCEPT和INTERSECT的文章就介绍到这了,更多相关SQL Server中的集合运算内容请搜索考高分网以前的文章或继续浏览下面的相关文章希望大家以后多多支持考高分网!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/168757.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号