ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

mysql UNION 和 UNION ALL

2021-11-12 12:00:36  阅读:164  来源: 互联网

标签:CN UNION country WHERE mysql com SELECT


描述

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  | stackoverflow | http://stackoverflow.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;

结果

 

 

 注

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

UNION ALL

实例

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

结果

 

 

带有 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;

结果

 

 

总结

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

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

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

 

标签:CN,UNION,country,WHERE,mysql,com,SELECT
来源: https://www.cnblogs.com/zydr/p/15543872.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有