mysql UNION 和 UNION ALL

描述

MySQL UNION 操作符用于连接两个以上的 SELECT 语句的结果组合到一个结果集合中。多个 SELECT 语句会删除重复的数据。

语法

  SELECT expression1, expression2, ... expression_n FROM tables [WHERE conditions] UNION [ALL | DISTINCT]
  SELECT expression1, expression2, ... expression_n FROM tables [WHERE conditions];

参数

  expression1, expression2, ... expression_n: 要检索的列。
  tables: 要检索的数据表。
  WHERE conditions: 可选, 检索条件。
  DISTINCT: 可选,删除结果集中重复的数据。默认情况下 UNION 操作符已经删除了重复数据,所以 DISTINCT 修饰符对结果没啥影响。
  ALL: 可选,返回所有结果集,包含重复数据。

演示

 Websites 表的数据:
  mysql> SELECT * FROM Websites;
+----+--------------+---------------------------+-------+---------+
| id | name         | url                       | alexa | country |
+----+--------------+---------------------------+-------+---------+
| 1  | Google       | https://www.google.cm/    | 1     | USA     |
| 2  | 淘宝          | https://www.taobao.com/   | 13    | CN      |
| 3  | 菜鸟教程      | http://www.runoob.com/    | 4689  | CN      |
| 4  | 微博          | http://weibo.com/         | 20    | CN      |
| 5  | Facebook     | https://www.facebook.com/ | 3     | USA     |
| 7  | * | http://*.com/ |   0 | IND     |
+----+---------------+---------------------------+-------+---------+
apps APP 的数据:
  mysql> SELECT * FROM apps; +----+------------+-------------------------+---------+ | id | app_name | url | country | +----+------------+-------------------------+---------+ | 1 | QQ APP | http://im.qq.com/ | CN | | 2 | 微博 APP | http://weibo.com/ | CN | | 3 | 淘宝 APP | https://www.taobao.com/ | CN | +----+------------+-------------------------+---------+

 实例

SELECT country FROM Websites UNION
SELECT country FROM apps
ORDER BY country;

结果

mysql UNION 和 UNION ALL

 

 

 注

UNION 不能用于列出两个表中所有的country。如果一些网站和APP来自同一个国家,每个国家只会列出一次。UNION 只会选取不同的值。如需去除所有数据,使用 UNION ALL 取值!

UNION ALL

实例

SELECT country FROM Websites UNION ALL
SELECT country FROM apps
ORDER BY country;

结果

mysql UNION 和 UNION ALL

 

 

带有 WHERE 的 UNION ALL

SELECT country, name FROM Websites WHERE country='CN' UNION ALL
SELECT country, app_name FROM apps WHERE country='CN'
ORDER BY country;

结果

mysql UNION 和 UNION ALL

 

 

总结

UNION 语句:用于将不同表中相同列中查询的数据展示出来;(不包括重复数据)

UNION ALL 语句:用于将不同表中相同列中查询的数据展示出来;(包括重复数据)

使用形式如下:
  SELECT 查询字段 FROM 表名 UNION 
  SELECT 查询字段 FROM 表名 ORDER BY 排序字段;   SELECT 查询字段 FROM 表名 UNION ALL
  SELECT 查询字段 FROM 表名称 ORDER BY 排序字段;

 

上一篇:python – 如何在peewee 2中创建一个带枚举的表模型?


下一篇:mysql – 在peewee中避免表连接中存在冲突的列标题