首页 > 编程笔记 > MySQL笔记 阅读:170

MySQL UNION和UNION ALL的用法与区别(非常详细,附带实例)

MySQL 中,利用 UNION 关键字可以给出多条 SELECT 语句,并将它们的结果组合成单个结果集。合并时,两个表对应的列数和数据类型必须相同。各个 SELECT 语句之间使用 UNION 或 UNION ALL 关键字分隔。

UNION 不使用关键字 ALL,执行的时候删除重复的记录,所有返回的行都是唯一的;使用关键字 ALL 的作用是不删除重复行也不对结果进行自动排序。

UNION 关键字的基本语法格式如下:
SELECT column,... FROM table1
UNION [ALL]
SELECT column,... FROM table2

【实例】查询所有价格小于 9 的水果的信息,查询 s_id 等于 101 和 103 所有的水果的信息,使用 UNION 连接查询结果,SQL 语句如下:
SELECT s_id, f_name, f_price FROM fruits WHERE f_price < 9.0 UNION SELECT s_id, f_name, f_price FROM fruits WHERE s_id IN(101,103);
合并查询结果如下:
+------+------------+---------+
| s_id | f_name     | f_price |
+------+------------+---------+
|  101 | apple      |    5.20 |
|  103 | apricot    |    2.20 |
|  104 | berry      |    7.60 |
|  107 | xxxx       |    3.60 |
|  105 | melon      |    8.20 |
|  101 | cherry     |    3.20 |
|  104 | lemon      |    6.40 |
|  105 | xbabay     |    2.60 |
|  102 | grape      |    5.30 |
|  107 | xbababa    |    3.60 |
|  101 | blackberry |   10.20 |
|  103 | coconut    |    9.20 |
+------+------------+---------+

如前所述,UNION 将多个 SELECT 语句的结果组合成一个结果集合。可以分开查看每个 SELECT 语句的结果:
mysql> SELECT s_id, f_name, f_price FROM fruits WHERE f_price < 9.0;
+------+---------+---------+
| s_id | f_name  | f_price |
+------+---------+---------+
|  101 | apple   |    5.20 |
|  103 | apricot |    2.20 |
|  104 | berry   |    7.60 |
|  107 | xxxx    |    3.60 |
|  105 | melon   |    8.20 |
|  101 | cherry  |    3.20 |
|  104 | lemon   |    6.40 |
|  105 | xbabay  |    2.60 |
|  102 | grape   |    5.30 |
|  107 | xbababa |    3.60 |
+------+---------+---------+

mysql> SELECT s_id, f_name, f_price FROM fruits WHERE s_id IN(101,103);
+------+------------+---------+
| s_id | f_name     | f_price |
+------+------------+---------+
|  101 | apple      |    5.20 |
|  103 | apricot    |    2.20 |
|  101 | blackberry |   10.20 |
|  101 | cherry     |    3.20 |
|  103 | coconut    |    9.20 |
+------+------------+---------+
由分开查询的结果可以看到,第 1 条 SELECT 语句查询价格小于 9 的水果,第 2 条 SELECT 语句查询供应商 101 和 103 提供的水果。使用 UNION 将两条 SELECT 语句分隔开,执行完毕之后把输出结果组合成单个的结果集,并删除重复的记录。

使用 UNION ALL 包含重复的行,在前面的例子中,分开查询时,两个返回结果中有相同的记录。UNION 从查询结果集中自动去除了重复的行,如果要返回所有匹配行,而不进行删除,可以使用 UNION ALL。

【实例】查询所有价格小于 9 的水果的信息,查询 s_id 等于 101 和 103 的所有水果的信息,使用 UNION ALL 连接查询结果,SQL 语句如下:
SELECT s_id, f_name, f_price FROM fruits WHERE f_price < 9.0 UNION ALL
SELECT s_id, f_name, f_price FROM fruits WHERE s_id IN(101,103);
查询结果如下:
+------+------------+---------+
| s_id | f_name     | f_price |
+------+------------+---------+
|  101 | apple      |    5.20 |
|  103 | apricot    |    2.20 |
|  104 | berry      |    7.60 |
|  107 | xxxx       |    3.60 |
|  105 | melon      |    8.20 |
|  101 | cherry     |    3.20 |
|  104 | lemon      |    6.40 |
|  105 | xbabay     |    2.60 |
|  102 | grape      |    5.30 |
|  107 | xbababa    |    3.60 |
|  101 | apple      |    5.20 |
|  103 | apricot    |    2.20 |
|  101 | blackberry |   10.20 |
|  101 | cherry     |    3.20 |
|  103 | coconut    |    9.20 |
+------+------------+---------+
由结果可以看到,这里总的记录数等于两条SELECT语句返回的记录数之和,连接查询结果并没有去除重复的行。

UNION和UNION ALL的区别

使用 UNION ALL 的功能是不删除重复行,加上 ALL 关键字语句执行时所需要的资源少,所以尽可能地使用它。

知道有重复行但是想保留这些行,确定查询结果中不会有重复数据或者不需要删除重复数据的时候,应当使用 UNION ALL 以提高查询效率。

相关文章