1、知识点

先了解一下集合概念,集合运算(UNION(并)、EXCEPT(补)、INTERSECT(交))是指表之间的垂直操作。区别联接(CROSS,INNER、OUTER)是指表之间的水平操作,基础知识:笛卡尔积,对多个表执行联接操作所得到的虚拟表包含这两个表的所有列。

今天我们主要来说集合运算。

UNION运算返回俩个输入中的行的并集;EXCEPT返回在第一个输入中出现但在第二个输入中没有出现的行;INTERSECT返回在俩个输入中都出现的行。

2、union和union all

a.集合运算的时候不支持使用可选DISTINCT,因为没有指定all时,DISTINCT是隐含的。

b.集合运算的俩个输入必须具备相同的列数,而且相应列必须可以相同的数据类型,或者至少可以隐式的转换,列的名称由第一个输入决定。

c.在单独的表,表达式不允许使用order by 子句,支持所有其他的逻辑处理(联接,筛选,分组)

d.对于集合运算的最终结果,order by 是唯一允许对其直接进行操作的逻辑处理阶段。

在我们处理数据的时候,需要将多个sql结果合并起来,这个时候就需要用到union和union all。例如:

 SELECT * FROM (SELECT TOP ( 1 ) jm.*
FROM dbo.JM_FutureIncomeSource jm
LEFT JOIN dbo.v_FY_Room rm ON rm.RoomNO = jm.RoomNo
WHERE rm.ZoneID = '' AND jm.RemainingMonths BETWEEN 30 AND 36 AND jm.FutureIncome>20000 ORDER BY rm.CreateDate ASC ) a
UNION ALL
SELECT * FROM (SELECT TOP ( 1 ) jm.*
FROM dbo.JM_FutureIncomeSource jm
LEFT JOIN dbo.v_FY_Room rm ON rm.RoomNO = jm.RoomNo
WHERE rm.ZoneID = '' AND jm.RemainingMonths BETWEEN 58 AND 63 AND jm.FutureIncome>20000 ORDER BY rm.CreateDate ASC )b

sql格式 

[SQL 语句 1]
UNION(all)
[SQL 语句 2]

3、union和union all的区别

union 不带all,隐式带distinct,并在结果上应用distinct(删除重复行)

union all 是没有删除重复行的union。

4、EXCEPT (补)

ecxept 返回在第一个输入中出现,第二输入没有出现的不重复行。

返回在employees出现的城市,但是没有在customers出现的

5、INTERSECT(交)

返回在俩个输入中都出现的行(支持隐含distinct形式)

 SELECT 6 AS age
INTERSECT
SELECT 6 AS age

性能分析,可以看出顶部输入扫描和底部输入扫描匹配开销最大。

6、集合运算的优先级

INTERSECT集合运算比其他集合运算的优先级更高,最先执行INTERSECT,但是可以依靠圆括号来控制逻辑顺序。

T-Sql之集合的更多相关文章

  1. SQL进阶系列之7用SQL进行集合运算

    写在前面 集合论是SQL语言的根基,因为这种特性,SQL也被称为面向集合语言 导入篇:集合运算的几个注意事项 注意事项1:SQL能操作具有重复行的集合(multiset.bag),可以通过可选项ALL ...

  2. SQL的集合运算符介绍

    最近学习了SQL SERVER方面的知识,毕竟做Web应用,少不了跟数据库打交道.学习的来源主要是<程序员的SQL金典>这本书. 今天介绍数据库里面的集合运算符,它是指匹配集合的每一个结果 ...

  3. sql的集合操作

    原文转自:http://blog.csdn.net/qsyzb/article/details/12560917 SELECT语句的查询结果是元组的集合,所以多个SELECT语句的结果可进行集合操作. ...

  4. PL/SQL 记录集合IS TABLE OF的使用

    在PL/SQL代码块中使用select into 赋值的话,有可能返回的是一个结果集.此时,如果使用基本类型或自定义的记录类型,将会报错. 因此,需要定义一个变量,是某种类型的集合.下面以一个基于表的 ...

  5. Oracle_PL/SQL(7) 集合

    pl/sql集合处理单行单列数据,可以使用标量变量:处理单行多列的数据,可以使用pl/sql记录(%rowtype,record):处理单列多行数据,可以使用pl/sql集合. pl/sql集合类型是 ...

  6. 用python(2.7)自定义实现SQL的集合操作

    有的时候需要在不同的数据库实例之间做集合操作,这就无法直接使用SQL语句的join,left join了.相同类型的数据库之间虽然也有类似于DBLINK和FEDERATED之类的东西,但一来这些东西不 ...

  7. SQL 语句集合

    创建数据库 创建之前判断该数据库是否存在 if exists (select * from sysdatabases where name='databaseName') drop database ...

  8. SQL函数集合

    1. PATINDEX ( '%pattern%' , expression ) 返回pattern字符串在表达式expression里第一次出现的位置,起始值从1开始算. pattern字符串在ex ...

  9. sql的集合运算

    表的加减法 union:使用union 对表进行假发(并集)运算, union等集合运算符通常都会去除重复记录. select shohin_id, shohin_mei from shohin un ...

  10. 常用SQL语句集合

    一.数据定义 1.创建新数据库:CREATE DATABASE database_name2.创建新表:CREATE TABLE table_name (column_name datatype,co ...

随机推荐

  1. 常见反编译产生错误 k__BackingField 解决办法

    常见反编译产生错误 k__BackingField 解决办法     无聊反编译小蚂蚁出现上千的错同样的错       private bool <EnableRuntimeHandler> ...

  2. js阻止冒泡和默认事件(默认行为)详解- jquery DefaultPrevented 函数

    <!DOCTYPE html> <html>     <head>     <meta charset="UTF-8">     & ...

  3. hive中分组取前N个值的实现

    背景 假设有一个学生各门课的成绩的表单,应用hive取出每科成绩前100名的学生成绩. 这个就是典型在分组取Top N的需求. 解决思路 对于取出每科成绩前100名的学生成绩,针对学生成绩表,根据学科 ...

  4. SpringMVC 学习笔记(处理器映射器的配置)

    前端控制器(dispatchServlet) 在web.xml中配置前端控制器,在服务器启动时就被创建,用来对请求和响应进行接收 和 分发处理,其在配置时可以设置一个初始化参数,用来定位SpringM ...

  5. 【常见CPU架构对比】维基百科

    Comparison of instruction set architectures https://en.wikipedia.org/wiki/Comparison_of_instruction_ ...

  6. 问题记录,StartCoroutine(“str")问题

    StartCoroutine参数为函数字符串名,运行时出错,错误是:无法启动协程函数. 调用格式如下: gameManager.StartCoroutine(LuaOnLevelwasloaded() ...

  7. 《C语言基础日常笔记》

    1. 类型转换-----------------20130902 a, 浮点数(包括单精度与双精度)赋值给整型变量时,舍弃浮点数的小数部分,直接将其整数部分存放在整型变量里. b, 整型变量赋值给浮点 ...

  8. Proxmox VE 添加软RAID

    apt-get update; apt-get install mdadm     安装软件 mdadm -C <设备名字> 创建模式 -l raid等级,0,1,5之类的 -n 使用的磁 ...

  9. modern.IE

    1.主要测试IE浏览器的兼容性问题 2.网站上提供各种虚拟机来表现兼容性问题,可以像平常一样使用浏览器测试,但是中国访问速度比较慢 3.网址:http://loc.modern.ie/zh-cn/vi ...

  10. python:dist-packages && site-packages

    先简单描述下问题.我用的ubuntu,源码编译安装的python3.我安装一些库,需要通过apt-get方式安装,这个时候就会遇到python找不到这些库的问题. 有个文章可以简单看看:http:// ...