描述

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 输出结果如下:

注释: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 输出结果如下:


带有 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 操作符(十七)相关推荐

  1. 零基础mysql项目实例_MySQL-零基础开发

    1.终端下连接mysql服务 mysql -uroot -p回车后输入设定的密码即可. 进去后每条命令结尾要带分号:退出命令exit 单行注释有两种:# 或 --空格.多行注释/* */ 2.基本命令 ...

  2. 8小时8节零基础MySQL快速人门实验上机课

    第一次实验:数据库设计(1) 一.实训目的 (1)掌握E-R图设计的基本方法,能绘制局部E-R图,并集成全局E-R图 (2)将概念模型转换为关系模型 二.实验内容 1.设计图书借阅系统数据库--Lib ...

  3. salesforce零基础学习(九十七)Big Object

    我们在salesforce学习工作中,接触到很多的 标准的 object ,自定义 object 以及外部object.我们使用SOQL / SOSL 进行搜索,熟知他们的各种limitation,查 ...

  4. MySQL(18)--- UNION 操作符

    MySQL UNION 操作符 本教程为大家介绍 MySQL UNION 操作符的语法和实例. 描述 MySQL UNION 操作符用于连接两个以上的 SELECT 语句的结果组合到一个结果集合中.多 ...

  5. 零基础可以学python么

    零基础自然是可以学习python的,Python具有简单.易学.免费.开源.可移植.可扩展.面向对象等优点,斩获无数程序员的喜爱,也有了"人生苦短,我选Python"的名言. 近几 ...

  6. 零基础入门python好学么

    python对于零基础的小伙伴算是非常友好的了~ python以简单易学著称~ Python简洁,高效的特点,大大提升了程序员的编码速度,极大的提高了程序员的办公效率,比如用其他编程语言5.6行代码才 ...

  7. 零基础学习大数据分析难吗?

    之前看到过一个行业招聘难度的对比,在这里列一下:(来源是<2021年互联网人才招聘白皮书>) 无论是DBA还是大数据分析师,和java前端后端相比,都不算是最卷的,甚至还算是挺好的, 你看 ...

  8. 零基础转行IT互联网岗位月入过万需要多久?

    零基础转行IT互联网岗位月入过万需要多久? 要知道影响薪资水平的因素有学科,技术水平,项目经验,地域等诸多方面,零基础转行学习6个达到月薪过万的不在少数,新入行的程序员在BAT和二线互联网公司的校园招 ...

  9. 零基础学习大数据可以找到工作么?

    现在开始学习大数据晚了吗?现在学习大数据后还好就业吗?随着互联网应用基础的不断普及,大数据技术已经成为互联网企业的标配.大数据技术已经在国内持续火爆了几年的时间.每年都有大量的人才涌入到大数据行业中, ...

最新文章

  1. 浪潮服务器开始虚拟化,(浪潮服务器-虚拟化解决方案.ppt
  2. 以太坊节点布置(3) 启动geth客户端
  3. 【Tomcat Eclipse】8080端口被占用问题记录
  4. JavaScriptCore全面解析
  5. Inno Setup使用技巧
  6. 理解与学习linux 文件系统的目录结构
  7. Linux下Java安装与配置
  8. kotlin android 注解,注解 - Kotlin 语言中文站
  9. jdk1.8的安装与环境变量配置
  10. 隐藏在计算机软硬件,隐匿在计算机软硬件背后的语言
  11. Win 7 配置FTP权限
  12. 定时器/计数器、中断
  13. delta波 意识(摘要)
  14. 如何截取音频片段并制作成手机铃声
  15. O2O模式为什么这么火
  16. 脑机接口中的流形嵌入知识迁移学习
  17. 小米盒子显示服务器断开,【当贝市场】小米盒子4网络掉线怎么办?解决办法...
  18. HDLBits 系列(7)——Sequential Logic(Counters、Shift Registers、More Circuits)
  19. 2022-9-27 学习笔记
  20. 提取lbp特征java代码_目标检测的图像特征提取之_LBP特征

热门文章

  1. JAVA minaio模型_分布式系统之Java IO模型
  2. tina中信号带宽_如何评测示波器带宽
  3. ll微信2下载安装_【兰苑文学】:陈振 ll黄金槐
  4. 计算机数学基础 刘树利,计算机数学基础课件教学课件作者刘树利11课件.ppt
  5. matlab读取data格式,ReadData3D 各种格式图像的读取,包括医学 效果很好 matlab 272万源代码下载- www.pudn.com...
  6. Win7系统提示NVIDIA显示设置不可用怎么办
  7. UC浏览器怎样收藏视频
  8. IE浏览器网页无法缩放怎么办 解决IE浏览器网页无法缩放的方法
  9. 360浏览器如何进行皮肤更换
  10. MUI tab选项卡之间的切换和数据获取