Mysql基础教程(14):UNION

MySQL UNION 的用法与实例

在本文中,我们讨论在 MySQL 中对两个结果集进行 UNION 运算,以及 UNION 运算的规则。

在 MySQL 中,UNION 操作符是一个集合操作符,它用于合并 【2 个结果集】中的所有的行。

SQL 标准中定义了 3 个集合操作符: UNION, INTERSECT 和 MINUS。目前 MySQL 只支持 【UNION】

UNION操作符语法

UNION 操作符用来合并两个 SELECT 语句的结果集。UNION 操作符的语法如下:

SELECT statement
UNION [DISTINCT | ALL]
SELECT statement

说明:

  • UNION 双目操作符,需要两个 SELECT 语句作为操作数。
  • UNION 中的 SELECT 语句中的列数、列顺序必须相同
  • UNION 运算包括 UNION DISTINCT 和 UNION ALL 两种算法,其中 UNION DISTINCT 可以简写为 UNION。
  • UNION DISTINCT 或 UNION 将过滤掉结果集中重复记录
  • UNION ALL 将返回结果集中的所有记录

UNION实例

建立测试表和测试数据

在以下实例中,我们创建 a 和 b 两个表进行演示。

创建测试表并插入测试数据

CREATE TABLE a (v INT);
CREATE TABLE b (v INT);
CREATE TABLE c (v INT);INSERT INTO a VALUES (1), (2), (NULL), (NULL);
INSERT INTO b VALUES (2), (2), (NULL);
INSERT INTO c VALUES (3), (2);

a 表数据:

+------+
| v    |
+------+
|    1 |
|    2 |
| NULL |
| NULL |
+------+
4 rows in set (0.00 sec)

b 表数据:

+------+
| v    |
+------+
|    2 |
|    2 |
| NULL |
+------+
3 rows in set (0.00 sec)

c 表数据:

+------+
| v    |
+------+
|    3 |
|    2 |
+------+
2 rows in set (0.00 sec)

UNION 运算

以下语句对从 a 和 b 表返回的两个结果集进行 UNION 运算:

SELECT * FROM a
UNION
SELECT * FROM b;
+------+
| v    |
+------+
|    1 |
|    2 |
| NULL |
+------+
3 rows in set (0.00 sec)

从输出的结果可以看出,UNION 运算删除了结果集中的重复项,返回一个唯一记录值的结果集。

UNION 是 UNION DISTINCT 的简写。

除了对两个表的记录进行 UNION 运算,也可以对 a, b 和 c 这 3 个表的记录进行 UNION 运算。如下:

SELECT * FROM a
UNION
SELECT * FROM b
UNION
SELECT * FROM c;
+------+
| v    |
+------+
|    1 |
|    2 |
| NULL |
|    3 |
+------+
4 rows in set (0.00 sec)

本例等同于如下的运算步骤:

  1. 首先对 a 和 b 表的记录进行 UNION 运算,并返回结果集。
  2. 将第 1 步的结果集和 c 表的记录进行 UNION 运算。

UNION ALL运算

以下语句对从 a 和 b 表返回的两个结果集进行 UNION ALL 运算:

SELECT * FROM a
UNION ALL
SELECT * FROM b;
+------+
| v    |
+------+
|    1 |
|    2 |
| NULL |
| NULL |
|    2 |
|    2 |
| NULL |
+------+
7 rows in set (0.00 sec)

从输出的结果可以看出,UNION ALL 保留了两个结果集中的所有行。

除了对两个表的记录进行 UNION ALL 运算,也可以对 a, b 和 c 这 3 个表的记录进行 UNION ALL 运算。如下:

SELECT * FROM a
UNION ALL
SELECT * FROM b
UNION ALL
SELECT * FROM c;

UNION 与 UNION ALL 组合运算

请看以下实例:

SELECT * FROM a
UNION
SELECT * FROM b
UNION ALL
SELECT * FROM c;
+------+
| v    |
+------+
|    1 |
|    2 |
| NULL |
|    3 |
|    2 |
+------+
5 rows in set (0.00 sec)

本例的运算步骤如下:

  1. 首先对 a 和 b 表的记录进行 UNION 运算,并返回结果集。这一步运算删除了 a 和 b 表的重复记录。
  2. 将第 1 步的结果集和 c 表的记录进行 UNION ALL 运算。这一步并没有删除 c 表中与第 1 部结果集中的重复记录。

UNION排序

当需要对 UNION 运算的结果进行排序时,最需要在 SQL 语句的最后添加 ORDER BY 子句。

以下语句对从 a 和 b 表返回的两个结果集进行 UNION ALL 运算,并升序排序:

SELECT * FROM a
UNION ALL
SELECT * FROM b
ORDER BY v;
+------+
| v    |
+------+
| NULL |
| NULL |
| NULL |
|    1 |
|    2 |
|    2 |
|    2 |
|    3 |
+------+
8 rows in set (0.01 sec)

UNION列数

当对两个结果集进行 UNION 运算的时候,要保证每个结果集具有相同的列数。否则就会产生错误。

请看如下的实例:

SELECT 1
UNION
SELECT 2, 3;
ERROR 1222 (21000): The used SELECT statements have a different number of columns

这是因为 SELECT 1 只有 1 列,而 SELECT 2, 3 则有 2 列数据。两个结果集列数不一样,导致了 UNION 运算产生错误

结论

  1. UNION 运算用于将两个结果集合成一个,是数据行维度的组合。
  2. UNION 运算包括 UNION DISTINCT 和 UNION ALL 两种算法,其中 UNION DISTINCT 可以简写为 UNION。
  3. UNION 会删除两个结果集中的重复记录行,而 UNION ALL 则保留全部记录行。
  4. UNION 运算要求参与运算的两个结果集的列数必须一样。
  5. UNION 运算取第一个参与运算的结果集的列名作为最终的列名。
  6. 可以使用 ORDER BY 对 UNION 运算的结果进行排序。

⬅ Mysql基础教程(13):GROUP BY

➔ Mysql基础教程(15):别名

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/24286.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MongoDB 正则表达式详解:高效数据查询与处理技巧

MongoDB 的正则表达式(Regular Expression)功能允许在查询中进行模式匹配和文本搜索,为用户提供了强大的灵活性。 基本语法 MongoDB 中使用正则表达式时,通常是在查询语句中使用 $regex 操作符。基本语法如下: { &l…

Spring AI 第二讲 之 Chat Model API 第八节Anthropic 3 Chat

Anthropic Claude 是一系列基础人工智能模型,可用于各种应用。对于开发人员和企业来说,您可以利用 API 访问,直接在 Anthropic 的人工智能基础架构之上进行构建。 Spring AI 支持用于同步和流式文本生成的 Anthropic 消息 API。 Anthropic …

MSA(the Method of Successive Averages)算法的满足条件是怎么来的?

文章目录 摘要前言MSA算法MSA算法简介与来源算法收敛性证明使用MSA算法对确定性网络均衡问题收敛性的验证使用MSA算法对随机网络均衡问题收敛性的验证 此文章属于文献研读内容,文章内容来源于以下文献 Warren B. Powell, Yosef Sheffi , (1982) The Convergence of …

二轴机器人大米装箱机:技术创新引领智能包装新潮流

在科技日新月异的今天,自动化和智能化已成为各行各业追求高效、精准生产的关键。作为粮食加工行业的重要一环,大米装箱机的技术创新与应用价值日益凸显。其中,二轴机器人大米装箱机以其高效、稳定、智能的特点,成为市场的新宠。星…

Python怎么循环计数:深入解析与实践

Python怎么循环计数:深入解析与实践 在Python编程中,循环计数是一项基础且重要的技能。无论是处理列表、遍历文件,还是执行重复任务,循环计数都发挥着不可或缺的作用。本文将从四个方面、五个方面、六个方面和七个方面详细阐述Py…

Python爬虫小练习

爬虫的本质 爬虫的本质就是通过程序模拟正常人向网站发送请求获取信息。 关于爬虫的一些闲聊 按照我们的常识来说,我们不可能在1秒钟访问这个网站100次,请求100次数据,所以过多的请求很有可能会被网站认为你在使用脚本进行爬虫&#xff0c…

从入门到精通:基础IO

引言 在编程的世界里,文件输入输出(IO)是与操作系统交互的重要方式。无论你是开发应用程序、处理数据,还是管理系统资源,掌握文件IO操作都是必不可少的。本篇博客将带你深入了解C语言中的基础IO操作,从入门…

使用 IPSET 添加 CDN 节点 IP(IPv4/IPv6)到防火墙白名单

明月的服务器一直使用的是 iptables,随着近几年 IPv6 的普及,明月切身体会到还是 IPSET 最方便了,无论你是 IPv4 还是 IPv6 都可以方便的管理,无论你是加入白名单还是黑名单,都非常的简单高效!今天就参照明月自己的实操…

东方博宜1317 - 正多边形每个内角的度数?

问题描述 根据多边形内角和定理,正多边形内角和等于:( n-2 ) 180∘( n 大于等于 3 且 n 为整数)。 请根据正多边形的边数,计算该正多边形每个内角的度数。(结果保留1位小数&#x…

Python 机器学习 基础 之 【实战案例】新闻内容分类实战

Python 机器学习 基础 之 【实战案例】新闻内容分类实战 目录 Python 机器学习 基础 之 【实战案例】新闻内容分类实战 一、简单介绍 二、新闻内容分类实战 三、数据准备 四、分词与清洗工作 1、读取数据 2、使用 jieba 分词器进行分词,使用 Pandas 创建Data…

cesium已知两个点 写一个简单具有动画尾迹效果的抛物线

// 定义起点和终点的经纬度和高度 var start = {longitude: 111.09683723811149, latitude: 38.92112250636146, elevation: 603.5831692856873 }; var end = {longitude: 111.09769465526689, latitude: 38.92815375977821, elevation: 627.0132157062261 }; // 生成更多的中…

【亲测可用】Linux的wget太慢,使用mwget加速下载

微信公众号:leetcode_algos_life,代码随想随记 小红书:412408155 CSDN:https://blog.csdn.net/woai8339?typeblog ,代码随想随记 GitHub: https://github.com/riverind 抖音【暂未开始,计划开始】&#xf…

R语言探索与分析19-CPI的分析和研究

一、选题背景 CPI(居民消费价格指数)作为一个重要的宏观经济指标,扮演着评估通货膨胀和居民生活水平的关键角色。在湖北省这个经济活跃的地区,CPI的波动对于居民生活、企业经营以及政府宏观经济政策制定都具有重要的影响。因此&a…

ES 面试手册

Elasticsearch是什么? Elasticsearch是一个基于Lucene的搜索和分析引擎,它提供了一个分布式、多租户能力的全文搜索引擎,具有HTTP Web界面和无模式JSON文档。 Elasticsearch中的倒排索引是什么? 倒排索引是搜索引擎的核心结构&a…

Java——面向对象进阶(一)

前言 面向对象进阶(一):static,继承,this和super关键字 文章目录 一、static1.1 静态变量1.2 静态方法1.3 静态变量和静态方法在内存中 二、继承2.1 概念2.2 继承的特点和能继承什么2.3 继承中的重写2.4 this和super关键字 一、static 在 Jav…

Java学习笔记(六):Array List、学生管理系统、学生管理系统升级版

目录 一、ArrayList 1.1集合和数组的优势对比: 1.2 ArrayList类概述 1.3 ArrayList类常用方法 1.3.1 构造方法 1.3.2 成员方法 1.4 ArrayList存储字符串并遍历 1.5 ArrayList存储学生对象并遍历 1.6 查找用户的索引 1.7 添加手机对象并返回要求的数据 二…

谈AI 时代网站的未来趋势

以大语言模型为代表的AI 技术迅速发展,将会影响原有信息网络的方式。其中一个明显的趋势是通过chatGPT 对话代替搜索引擎和浏览器来获取信息。 互联网时代,主要是通过网站(website)提供信息。网站主要为人类阅读的方式构建的。主要…

kali-vulhub(持续更新)

一些自己用kali搭建vulhub的便捷及问题 自己的环境kali2024.1 / Debian12 x 64 kali安装或更换jdk版本 自带的是jdk17 环境要求是jdk8 下载java包放到kali mkdir -p /usr/local/java cp jdk-8u202-linux-x64.tar.gz /usr/local/java cd /usr/local/java tar x…

数据结构笔记1 绪论,线性表

学习视频: 第01周c--1.2基本概念和术语1_哔哩哔哩_bilibili 01《数据结构》绪论_哔哩哔哩_bilibili 数据: 1.数值型的数据:整数,实数 2.非数值型的数据:文字、图像.. 数据元素:(元素&#xf…

人类语言处理nlp部分笔记——四、GPT3

参考自李宏毅课程-人类语言处理 四、GPT3 1. 介绍 GPT-3是一个language model,它的参数量相当巨大,是ELMO的2000倍。 2. GPT-3的野心 虽然GPT-3和BERT等模型一样,但是GPT-3是不需要针对特定的task做finetune的,也就是说GPT-3…