您的位置:首页 > 数据库 > SQL语言 > 正文

SQL Union和Union All的用法和区别

更多 时间:2014-1-14 类别:数据库 浏览量:3214

SQL Union和Union All的用法和区别

SQL Union和Union All的用法和区别

 

一、SQL UNION 操作符

 

UNION 操作符用于合并两个或多个 SELECT 语句的结果集。

请注意,UNION 内部的 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时,每条 SELECT 语句中的列的顺序必须相同。

 

SQL UNION 语法

 

SELECT column_name(s) FROM table_name1

UNION

SELECT column_name(s) FROM table_name2

 

使用 UNION 须满足以下条件:



A:所有查询中必须具有相同的结构(即查询中的的列数和列的顺序必须相同)。


B:对应列的数据类型可以不同但是必须兼容(所谓的兼容是指两种类型之间可以进行隐式转换,不能进行隐式转换则报错)。也可以用显式转换为相同的数据类型。


(当数据类型不同时,则根据数据类型优先级规则确定所产生的数据类型。如果类型相同,但精度、小数位数或长度不同,则根据用于合并表达式的相同规则来确定结果)(参照MSDN:数据类型优先级)


C:如果为XML数据类型则列必须等价(所有列都必须类型化为 XML 架构,或者为非类型化),如果类型化,这些列必须类型化为相同的 XML 架构集合。

 

UNION注意点


A: Transact-SQL 语句中可以使用多个 UNION 运算符


B:在使用了 UNION 运算符的各个 SELECT 语句不能包含它们自己的 ORDER BY 或 COMPUTE 子句。而只能在最终的组合结果集(即最后一个 SELECT 语句的后面)使用一个 ORDER BY 或 COMPUTE 子句。


C:在使用了 UNION 运算符的各个 SELECT 语句中可以使用 GROUP BY 和 HAVING 子句。
 

 

二、SQL UNION ALL语法

 

SELECT column_name(s) FROM table_name1

UNION ALL

SELECT column_name(s) FROM table_name2

 

 

三、UNION 和 UNION ALL的区别

 

1、UNION 在运行时先取出两个表的结果,再用排序空间进行排序删除重复的记录,最后返回结果集,如果表数据量大的话可能会导致用磁盘进行排序。


2、UNION ALL只是简单的将两个结果合并后就返回。这样,如果返回的两个结果集中有重复的数据,那么返回的结果集就会包含重复的数据了。


3、从效率上说,UNION ALL 要比UNION快很多,所以,如果可以确认合并的两个结果集中不包含重复的数据的话,那么就使用UNION ALL