MySQL UNION操作符基础知识点

作者:laozhang 时间:2024-01-21 10:24:31 

MySQL UNION 操作符

本教程为大家介绍 MySQL UNION 操作符的语法和实例。

描述

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

语法

MySQL UNION 操作符语法格式:


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: 可选,返回所有结果集,包含重复数据。

演示数据库

在本教程中,我们将使用 RUNOOB 样本数据库。

下面是选自 "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   |
+----+------------+-------------------------+---------+
3 rows in set (0.00 sec)

SQL UNION 实例

下面的 SQL 语句从 "Websites" 和 "apps" 表中选取所有不同的country(只有不同的值):

实例


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

执行以上 SQL 输出结果如下:

MySQL UNION操作符基础知识点

注释:UNION 不能用于列出两个表中所有的country。如果一些网站和APP来自同一个国家,每个国家只会列出一次。UNION 只会选取不同的值。请使用 UNION ALL 来选取重复的值!

SQL UNION ALL 实例

下面的 SQL 语句使用 UNION ALL 从 "Websites" 和 "apps" 表中选取所有的country(也有重复的值):

实例


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

执行以上 SQL 输出结果如下:

MySQL UNION操作符基础知识点

带有 WHERE 的 SQL UNION ALL

下面的 SQL 语句使用 UNION ALL 从 "Websites" 和 "apps" 表中选取所有的中国(CN)的数据(也有重复的值):

实例


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

执行以上 SQL 输出结果如下:

MySQL UNION操作符基础知识点

标签:MySQL,UNION
0
投稿

猜你喜欢

  • sql 取两值之间的数据方法(例:100-200之间的数据)

    2024-01-24 03:55:20
  • 解决Pycharm调用Turtle时 窗口一闪而过的问题

    2023-05-06 14:46:29
  • 详解Python中datetime库的使用

    2021-03-31 20:14:13
  • SQL Server重置IDENTITY属性种子值操作

    2024-01-27 22:50:11
  • PHP PDOStatement::errorInfo讲解

    2023-06-04 14:11:53
  • Python决策树之基于信息增益的特征选择示例

    2023-01-09 23:44:32
  • 浅谈Python的Django框架中的缓存控制

    2022-01-23 10:56:24
  • ASP.NET中MVC从后台控制器传递数据到前台视图的方式

    2023-06-29 07:09:39
  • 做网站要习惯化与去习惯化

    2008-06-18 13:36:00
  • Python是什么 Python的用处

    2021-12-20 05:55:37
  • Tornado路由与Application的实现

    2021-01-26 19:56:59
  • ASP 常见的连接字符串写法(access2007)

    2011-03-25 10:40:00
  • asp如何检测HTTP表头信息?

    2010-06-28 18:20:00
  • Anaconda中pkgs文件夹及如何清空PKGS

    2022-04-03 00:31:33
  • Python标准库json模块和pickle模块使用详解

    2021-12-24 16:17:14
  • JS作用域链详解

    2024-04-17 10:04:56
  • JavaScript中的64位加密及解密

    2009-12-23 19:10:00
  • Base64编码的深入认识与理解

    2023-03-05 08:44:01
  • python检测服务器端口代码实例

    2023-07-07 06:34:14
  • 从网页设计开始

    2008-06-30 12:17:00
  • asp之家 网络编程 m.aspxhome.com