UNION 和 UNION ALL 操作符

Posted gavanwanggw

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了UNION 和 UNION ALL 操作符相关的知识,希望对你有一定的参考价值。

UNION 操作符

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

注意:

1.UNION 内部的 SELECT 语句必须拥有同样数量的列

2.列也必须拥有相似的数据类型

3.每条 SELECT 语句中的列的顺序必须同样

UNION 语法

SELECT column_name(s) FROM table_name1
UNION
SELECT column_name(s) FROM table_name2

凝视:默认地,UNION 操作符选取不同的值。假设同意反复的值,请使用 UNION ALL。

UNION ALL 语法

SELECT column_name(s) FROM table_name1
UNION ALL
SELECT column_name(s) FROM table_name2

另外,UNION 结果集中的列名总是等于 UNION 中第一个 SELECT 语句中的列名。

以下的样例中使用的原始表:

Employees_China:

E_ID E_Name
01 Zhang, Hua
02 Wang, Wei
03 Carter, Thomas
04 Yang, Ming

Employees_USA:

E_ID E_Name
01 Adams, John
02 Bush, George
03 Carter, Thomas
04 Gates, Bill

使用 UNION 命令

实例

列出全部在中国和美国的不同的雇员名:

SELECT E_Name FROM Employees_China
UNION
SELECT E_Name FROM Employees_USA

结果

E_Name
Zhang, Hua
Wang, Wei
Carter, Thomas
Yang, Ming
Adams, John
Bush, George
Gates, Bill

凝视:这个命令无法列出在中国和美国的全部雇员。在上面的样例中。我们有两个名字同样的雇员,他们其中仅仅有一个人被列出来了。

UNION 命令仅仅会选取不同的值。

使用 UNION ALL 命令

UNION ALL 命令和 UNION 命令差点儿是等效的,只是 UNION ALL 命令会列出全部的值。

实例:

列出在中国和美国的全部的雇员:

SELECT E_Name FROM Employees_China
UNION ALL
SELECT E_Name FROM Employees_USA

结果

E_Name
Zhang, Hua
Wang, Wei
Carter, Thomas
Yang, Ming
Adams, John
Bush, George
Carter, Thomas
Gates, Bill

以上是关于UNION 和 UNION ALL 操作符的主要内容,如果未能解决你的问题,请参考以下文章

UNION 和 UNION ALL 操作符

UNION 和 UNION ALL 操作符

SQL UNION 和 UNION ALL 操作符

UNION 和 UNION ALL 操作符

SQL UNION 和 UNION ALL 操作符

Union和Union All到底有什么区别