概述

为什么使用集合运算:

  在集合运算中比联接查询和EXISTS/NOT EXISTS更方便。

并集运算(UNION)

并集:两个集合的并集是一个包含集合A和B中所有元素的集合。

在T-SQL中。UNION集合运算可以将两个输入查询的结果组合成一个结果集。需要注意的是:如果一个行在任何一个输入集合中出现,它也会在UNION运算的结果中出现。T-SQL支持以下两种选项:

(1)UNION ALL:不会删除重复行

-- union allselect country, region, city from hr.Employeesunion allselect country, region, city from sales.Customers;
-- unionselect country, region from hr.Employeesunionselect country, region from sales.Customers;

交集:两个集合(记为集合A和集合B)的交集是由既属于A,也属于B的所有元素组成的集合。

在T-SQL中,INTERSECT集合运算对两个输入查询的结果取其交集,只返回在两个查询结果集中都出现的行。

  INTERSECT集合运算在逻辑上会首先删除两个输入集中的重复行,然后返回只在两个集合中中都出现的行。换句话说:如果一个行在两个输入集中都至少出现一次,那么交集返回的结果中将包含这一行。

  例如,下面返回既是雇员地址,又是客户地址的不同地址:

-- intersectselect country, region, city from hr.Employeesintersectselect country, region, city from sales.Customers;

差集运算(EXCEPT)

差集:两个集合(记为集合A和集合B)的由属于集合A,但不属于集合B的所有元素组成的集合。

 在T-SQL中,集合之差使用EXCEPT集合运算实现的。它对两个输入查询的结果集进行操作,反会出现在第一个结果集中,但不出现在第二个结果集中的所有行。

  EXCEPT结合运算在逻辑上首先删除两个输入集中的重复行,然后返回只在第一个集合中出现,在第二个结果集中不出现的所有行。换句话说:一个行能够被返回,仅当这个行在第一个输入的集合中至少出现过一次,而且在第二个集合中一次也没出现过。

  此外,相比UNION和INTERSECT,两个输入集合的顺序是会影响到最后返回结果的。

  例如,借助EXCEPT运算,我们可以方便地实现属于A但不属于B的场景,下面返回属于员工抵制,但不属于客户地址的地址记录:

-- except select country, region, city from hr.Employeesexceptselect country, region, city from sales.Customers;

SQL定义了集合运算之间的优先级:INTERSECT最高,UNION和EXCEPT相等。

  换句话说:首先会计算INTERSECT,然后按照从左至右的出现顺序依次处理优先级相同的运算。

-- 集合运算的优先级select country, region, city from Production.Suppliersexceptselect country, region, city from hr.Employeesintersectselect country, region, city from sales.Customers;

集合运算的优先级

1.INTERSECT>UNION=EXCEPT

2.首先计算INTERSECT,然后从左到右的出现顺序依次处理优先级的相同的运算。

3.可以使用圆括号控制集合运算的优先级,它具有最高的优先级。

在排序函数的OVER字句中使用ORDER BY ( SELECT <常量> )可以告诉SQL Server不必在意行的顺序。

使用表表达式避开不支持的逻辑查询处理

集合运算查询本身并不持之除ORDER BY意外的其他逻辑查询处理阶段,但可以通过表表达式来避开这一限制。

  解决方案就是:首先根据包含集合运算的查询定义一个表表达式,然后在外部查询中对表表达式应用任何需要的逻辑查询处理。

(1)例如,下面的查询返回每个国家中不同的员工地址或客户地址的数量:

select country, COUNT(*) as numlocationsfrom (select country, region, city from hr.Employees union select country, region, city from sales.Customers) as Ugroup by country;
select empid,orderid,orderdate from (select top (2) empid,orderid,orderdate  from sales.Orders where empid=3 order by orderdate desc,orderid desc) as D1union allselect empid,orderid,orderdate from (select top (2) empid,orderid,orderdate  from sales.Orders where empid=5 order by orderdate desc,orderid desc) as D2;

更多相关文章

  1. MySQL 5.7.9 服务无法启动-“NET HELPMSG 3534”的解决方法
  2. MySQL系列多表连接查询92及99语法示例详解教程
  3. Linux下MYSQL 5.7 找回root密码的问题(亲测可用)
  4. MySQL 什么时候使用INNER JOIN 或 LEFT JOIN
  5. Android(安卓)- Manifest 文件 详解
  6. Android的Handler机制详解3_Looper.looper()不会卡死主线程
  7. Selector、shape详解(一)
  8. Android(安卓)-- Android(安卓)JUint 与 Sqlite
  9. android2.2资源文件详解4--menu文件夹下的菜单定义

随机推荐

  1. 如何用Python快速优雅的批量修改Word文档
  2. 爬虫遇到头疼的验证码?Python实战讲解弹窗
  3. 提高内存使用效能的技巧
  4. 爬取B站20万+条弹幕,我学会了如何成为B站
  5. 原理+代码|手把手教你使用Python实战反欺
  6. 用Python打造一款文件搜索工具,所有功能自
  7. 老板让我从几百个Excel中查找数据,我用Pyt
  8. 可视化工具不知道怎么选?深度评测5大Pytho
  9. 原理+代码|Python实战多元线性回归模型
  10. 原理+代码|Python基于主成分分析的客户信