T-Sql之集合
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之集合的更多相关文章
- SQL进阶系列之7用SQL进行集合运算
写在前面 集合论是SQL语言的根基,因为这种特性,SQL也被称为面向集合语言 导入篇:集合运算的几个注意事项 注意事项1:SQL能操作具有重复行的集合(multiset.bag),可以通过可选项ALL ...
- SQL的集合运算符介绍
最近学习了SQL SERVER方面的知识,毕竟做Web应用,少不了跟数据库打交道.学习的来源主要是<程序员的SQL金典>这本书. 今天介绍数据库里面的集合运算符,它是指匹配集合的每一个结果 ...
- sql的集合操作
原文转自:http://blog.csdn.net/qsyzb/article/details/12560917 SELECT语句的查询结果是元组的集合,所以多个SELECT语句的结果可进行集合操作. ...
- PL/SQL 记录集合IS TABLE OF的使用
在PL/SQL代码块中使用select into 赋值的话,有可能返回的是一个结果集.此时,如果使用基本类型或自定义的记录类型,将会报错. 因此,需要定义一个变量,是某种类型的集合.下面以一个基于表的 ...
- Oracle_PL/SQL(7) 集合
pl/sql集合处理单行单列数据,可以使用标量变量:处理单行多列的数据,可以使用pl/sql记录(%rowtype,record):处理单列多行数据,可以使用pl/sql集合. pl/sql集合类型是 ...
- 用python(2.7)自定义实现SQL的集合操作
有的时候需要在不同的数据库实例之间做集合操作,这就无法直接使用SQL语句的join,left join了.相同类型的数据库之间虽然也有类似于DBLINK和FEDERATED之类的东西,但一来这些东西不 ...
- SQL 语句集合
创建数据库 创建之前判断该数据库是否存在 if exists (select * from sysdatabases where name='databaseName') drop database ...
- SQL函数集合
1. PATINDEX ( '%pattern%' , expression ) 返回pattern字符串在表达式expression里第一次出现的位置,起始值从1开始算. pattern字符串在ex ...
- sql的集合运算
表的加减法 union:使用union 对表进行假发(并集)运算, union等集合运算符通常都会去除重复记录. select shohin_id, shohin_mei from shohin un ...
- 常用SQL语句集合
一.数据定义 1.创建新数据库:CREATE DATABASE database_name2.创建新表:CREATE TABLE table_name (column_name datatype,co ...
随机推荐
- Windows下cpu使用的监控
这里有一篇来自微软的文章,主要讲WPA如何使用,但是前面关于进程调度的介绍很给力,非常好的学习操作系统的材料: https://msdn.microsoft.com/en-us/library/jj6 ...
- linux下mysql的安装配置
http://blog.csdn.net/xiagege3/article/details/41852895 (实战用的此文,要求mysql源码必须是未编译的,需依赖cmake编译) http:/ ...
- 怎么改变Eclipse中项目的运行服务器
eclipse中-->选定项目-->右键-->弹出 Properties for项目名 -->选择server子项-->选择需要的server即可(Always use ...
- Apt-Cacher-ng 搭建缓存服务器
docker pull minimum2scp/apt-cacher-ng docker run -d -p 3142:3142 --name=cache -e ACNG_BACKENDS_DEBIA ...
- fork后父子进程文件描述问题
[fork后父子进程文件描述问题] 一张图可以浅析的解释: 参考:http://wenku.baidu.com/view/dd51581bff00bed5b9f31d8e.html
- 多产生半成品工单的问题 修改带SO的半成品工单无法分配给SO的问题的
原因:验货及VIP带SO的半成品MO无法分配给对应的SO问题, 解决: SELECT SL.ENTERPRISE , SL.ENGINE_ID , SL.SITEID , ML.MO_ID || '_ ...
- AnimationState
1.1 AnimationClip AnimationClip是Unity3D中播放动画的最基本对象,通过FBX导入的各个动画对象其实就是一个AnimationClip.这个类已关键帧的形式记录了骨骼 ...
- 为什么数组没有实现Iterable接口,但可以使用foreach语句遍历
在Java中,对于数组为什么能够使用foreach语句一直感觉很困惑. 对于能够使用foreach语句进行遍历的对象,只有两种情况,其中一种是遍历对象必须实现Iterable接口,实现ierator( ...
- 创建Kafka0.8.2生产者与消费者
一.下载安装Kafka0.8.2 二.vi config/server.properties 三.修改为advertised.host.name=192.168.1.76 四.rm -rf /tmp ...
- Docker RestApi Create mysql Container
docker 提供了创建容器的rest api http://192.168.150.6:8888/containers/create?name=demo-mysql docker mysql容器的参 ...