当前位置: 首页 > news >正文

MySQL 中的 UNION 语句

文章目录

    • 一、数据准备
    • 一、UNION 和 UNION ALL
    • 二、UNION 的执行顺序(UNION 和其他语句一同出现)
    • 三、MySQL 使用 UNION(ALL) + ORDER 导致排序失效
    • 四、UNION 报错语法

一、数据准备

-- 创建表
CREATE TABLE test_user (ID int(11) NOT NULL AUTO_INCREMENT,USER_ID int(11) DEFAULT NULL COMMENT '用户账号',USER_NAME varchar(255) DEFAULT NULL COMMENT '用户名',AGE int(5) DEFAULT NULL COMMENT '年龄',COMMENT varchar(255) DEFAULT NULL COMMENT '简介',PRIMARY KEY (ID)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;-- 数据插入语句
INSERT INTO test_user (ID, USER_ID, USER_NAME, AGE, COMMENT) VALUES ('1', '111', '开心菜鸟', '18', '今天很开心');
INSERT INTO test_user (ID, USER_ID, USER_NAME, AGE, COMMENT) VALUES ('2', '222', '悲伤菜鸟', '21', '今天很悲伤');
INSERT INTO test_user (ID, USER_ID, USER_NAME, AGE, COMMENT) VALUES ('3', '333', '认真菜鸟', '30', '今天很认真');
INSERT INTO test_user (ID, USER_ID, USER_NAME, AGE, COMMENT) VALUES ('4', '444', '高兴菜鸟', '18', '今天很高兴');
INSERT INTO test_user (ID, USER_ID, USER_NAME, AGE, COMMENT) VALUES ('5', '555', '严肃菜鸟', '21', '今天很严肃');
SELECT * FROM test_user u;

在这里插入图片描述

一、UNION 和 UNION ALL

UNION

连接数据集关键字,可以将两个查询结果集拼接为一个,会过滤掉相同的记录

UNION ALL

连接数据集关键字,可以将两个查询结果集拼接为一个,不会过滤掉相同的记录

-- 使用UNION
SELECT * FROM test_user u
UNION
SELECT * FROM test_user u;

在这里插入图片描述
使用 UNION ,可以看到查询结果只有 5 条数据。

-- 使用UNION ALL
SELECT * FROM test_user u
UNION ALL
SELECT * FROM test_user u;

在这里插入图片描述
使用 UNION ALL,可以看到查询结果有 10 条数据。

二、UNION 的执行顺序(UNION 和其他语句一同出现)

from—>on—>join—>where—>group by—>having+(聚合函数)—>select—>distinct—>UNION—>order by—>limit

UNION 的执行顺序在 ORDER BY 之前

请记住这个执行顺序,便可以知道 UNION 和其他语句一同出现的结果。

  1. UNION 和 WHERE 语句
-- 1、第二个子句中的 where 语句不能同时作用于两个select语句
-- 5 + 1,共计 6 条
SELECT *, 'table1' FROM test_user u 
UNION ALL
SELECT *, 'table2' FROM test_user u WHERE AGE = 30;

UNION 在 where 之后,所以第二个表的WHERE先筛选后进行数据集拼接;
在这里插入图片描述
如果想要把 where 作用所有结果集,可以通过再嵌套一个 select 。

-- 1、第二个子句中的 where 语句不能同时作用于两个select语句
-- 1 + 1,共计 2 条
-- 写法 1
SELECT * FROM 
(SELECT *, 'table1' FROM test_user u UNION ALLSELECT *, 'table2' FROM test_user u
) a 
WHERE AGE = 30;
-- 或者使用写法 2
SELECT *, 'table1' FROM test_user u WHERE AGE = 30
UNION ALL
SELECT *, 'table2' FROM test_user u WHERE AGE = 30
;

在这里插入图片描述

  1. UNION 和 GROUP 语句
-- 2、第二个子句中的 group by 语句不能同时作用于两个select语句
-- 5 + 3,共计 8 条
SELECT *, 'table1' FROM test_user u 
UNION ALL
SELECT *, 'table2' FROM test_user u GROUP BY AGE;

UNION 在 GROUP BY 之后,所以 table2 的 GROUP BY 先分组后进行数据集拼接;
在这里插入图片描述
2. UNION 和 HAVING 语句

-- 3、第二个子句中的 HAVING 语句不能同时作用于两个 select 语句
-- 5 + 1,共计 6 条
SELECT *, 'table1' FROM test_user u 
UNION ALL
SELECT *, 'table2' FROM test_user u HAVING AGE = 30 ;

UNION 在 HAVING 之后,所以 table2 的 HAVING 先过滤后进行数据集拼接;
在这里插入图片描述
3. UNION 和 ORDER BY 语句

-- 4、第二个子句中的 order by 语句可以同时作用于两个select语句 
-- 查询结果整体按照 age 进行了排序
SELECT *, 'table1' FROM test_user u 
UNION ALL
SELECT *, 'table2' FROM test_user u ORDER BY AGE;

因为当 UNION(ALL)语句和 ORDER BY语句同时出现,UNION(ALL)语句先执行。
在这里插入图片描述
4. UNION 和 LIMIT 语句

-- 只有1条数据,因为LIMIT在UNION之后执行
SELECT *, 'table1' FROM test_user u 
UNION ALL
SELECT *, 'table2' FROM test_user u limit 0,1;

只有1条数据,因为 LIMIT 在 UNION 之后执行。
在这里插入图片描述

  1. UNION 、 ORDER BY 和 LIMIT 语句
-- 5、第二个子句中的 order by ,LIMIT 语句同时作用于两个 select 语句 *********
-- 只有1条数据,age=30 UNION--->ORDER BY--->LIMIT
SELECT *, 'table1' FROM test_user u 
UNION ALL
SELECT *, 'table2' FROM test_user u order by age desc limit 0,1;

先拼接数据集,在按照 age 排序,最后使用 LIMIT 。
在这里插入图片描述

三、MySQL 使用 UNION(ALL) + ORDER 导致排序失效

通过以下两种方式解决:

  • 添加 LIMIT 字段
  • 额外增加排序字段
  1. SQL 1 如下
SELECT * FROM test_user u ORDER BY AGE;

在这里插入图片描述
2. SQL 2 如下

SELECT * FROM test_user u ORDER BY AGE DESC;

在这里插入图片描述
3. 查询结果集

(SELECT *, 'table1' FROM test_user u ORDER BY AGE) 
UNION ALL 
(SELECT *, 'table2' FROM test_user u ORDER BY AGE DESC);

可以看到此时 ORDER BY 语句失效了。

在这里插入图片描述
原因:UNION(ALL) + 会使 ORDER 失效

  1. 解决办法(1): 添加 LIMIT
-- 都加上 LIMIT
( SELECT *, 'table1' FROM test_user u ORDER BY AGE limit 10) 
UNION ALL 
( SELECT *, 'table2' FROM test_user u ORDER BY AGE DESC limit 10) 

在这里插入图片描述
最好的解决方案就是先查询后排序,避免上述情况发生。

  1. 解决办法(2) :添加额外的排序字段
select * from 
(( SELECT *, 'table1' AS name, row_number() over(ORDER BY AGE ) AS rn FROM test_user u ) UNION ALL ( SELECT *, 'table2' AS name, row_number() over(ORDER BY AGE DESC) AS rn FROM test_user u ) 
) a
order by name, rn;

额外需要两个字段,通过 row_number() over(order by column)进行表内排序,再通过 name 字段进行表排序。

在这里插入图片描述

四、UNION 报错语法

1. ORDER BY 语法报错

-- 语法错误
SELECT *, 'table1' FROM test_user u ORDER BY AGE
UNION ALL
SELECT *, 'table2' FROM test_user u ORDER BY AGE DESC;

第一个 SELECT 语句也使用了 ORDER BY ,导致报错。
在这里插入图片描述
解决方案:第一个 SELECT 语句加上括号。

-- 语法正确
(SELECT *, 'table1' FROM test_user u ORDER BY AGE)
UNION ALL
SELECT *, 'table2' FROM test_user u ORDER BY AGE DESC;

加上括号后,虽然不再报错,但是第一个 SELECT 语句的排序失效。

在这里插入图片描述
那要是上下两个都加上括号呢?

-- 语法正确
(SELECT *, 'table1' FROM test_user u ORDER BY AGE)
UNION ALL
(SELECT *, 'table2' FROM test_user u ORDER BY AGE DESC);

语法不报错,但是两个排序都失效了。

原因大家也清楚,前面第三小节已经讲过了,UNION 在 ORDER BY 语句之前。

在这里插入图片描述
2. LIMIT 语法报错

同样对于 LIMIT 语句也是一样的。

-- 语法错误
SELECT *, 'table1' FROM test_user u limit 0,1
UNION ALL
SELECT *, 'table2' FROM test_user u limit 0,1;

在这里插入图片描述

解决方案:同样也是第一个 SELECT 语句加上括号。

-- 语法正确,1 条记录
(SELECT *, 'table1' FROM test_user u limit 0,1)
UNION ALL
SELECT *, 'table2' FROM test_user u limit 0,1;

此时语法正确,但只返回一行记录。
在这里插入图片描述
如果想要返回两条记录,就给第二个 SELECT 语句也加上括号。

-- 语法正确,2 条记录
(SELECT *, 'table1' FROM test_user u limit 0,1)
UNION ALL
(SELECT *, 'table2' FROM test_user u limit 0,1);

在这里插入图片描述

总结: UNION 后面执行的 ORDER BY,LIMIT 语句注意使用时要加括号,否则报错。

相关文章:

MySQL 中的 UNION 语句

文章目录一、数据准备一、UNION 和 UNION ALL二、UNION 的执行顺序(UNION 和其他语句一同出现)三、MySQL 使用 UNION(ALL) ORDER 导致排序失效四、UNION 报错语法一、数据准备 -- 创建表 CREATE TABLE test_user (ID int(11) NO…...

高完整性系统工程(三): Logic Intro Formal Specification

目录 1. Propositions 命题 2.1 Propositional Connectives 命题连接词 2.2 Variables 变量 2.3 Sets 2.3.1 Set Operations 2.4 Predicates 2.5 Quantification 量化 2.6 Relations 2.6.1 What Is A Relation? 2.6.2 Relations as Sets 2.6.3 Binary Relations as…...

【linux】多线程概念详述

文章目录一、线程基本概念1.1 进程地址空间与页表1.2 页表结构1.3 线程的理解1.3.1 如何描述线程1.4 再谈进程1.5 代码理解1.5.1 原生库提供线程pthread_create1.6 资源共享问题1.7 资源私有问题二、总结2.1 什么是线程2.2 并行与并发2.3 线程的优点2.4 线程的缺点2.5 线程异常…...

【Java】P8 面向对象(3)方法 基本知识

面向对象 方法方法方法的声明权限修饰符返回值类型方法名形参列表方法体简单案例方法 方法 是对类或对象行为特征的抽象,用来完成某个功能的操作。方法的目的 是为了实现代码复用,减少冗余,简化代码;方法不能独立存在&#xff0c…...

js中null和undefined的区别

js中null和undefined的区别?这也是一个常见的js面试题 相同点 1,都是基本类型。 2,做判断值都是false。 !!null false // true !!undefined false // true不同点 1,诞生时间null在前,undefined在后。因为js作者Brendan-Eic…...

【Linux】linux中的c++怎么调试?gdb的介绍和使用。

背景1.1.前提知识程序的发布方式有两种,debug模式和release模式Linux gcc/g出来的二进制程序,默认是release模式 要使用gdb调试,必须在源代码生成二进制程序的时候, 加上 -g 选项windows上的调试方法有区别吗?1.调试思路是一样的2…...

提升Python代码性能的六个技巧

文章目录前言为什么要写本文?1、代码性能检测1.1、使用 timeit 库1.2、使用 memory_profiler 库1.3、使用 line_profiler 库2、使用内置函数和库3、使用内插字符串 f-string4、使用列表推导式5、使用 lru_cache 装饰器缓存数据6、针对循环结构的优化7、选择合适算法…...

VI的常用命令

VI的常用命令 文章目录VI的常用命令vi/vim是什么?VI普通模式命令VI编辑模式命令VI指令模式vi/vim是什么? VI是Unix操作系统和类Unix操作系统中最通用的文本编辑器 VIM编辑器是从VI发展出来的一个性能更强大的文本编辑器。可以主动的将字体颜色辨别语法…...

【数据结构】万字深入浅出讲解单链表(附原码 | 超详解)

🚀write in front🚀 📝个人主页:认真写博客的夏目浅石. 🎁欢迎各位→点赞👍 收藏⭐️ 留言📝 📣系列专栏:C语言实现数据结构 💬总结:希望你看完…...

无线WiFi安全渗透与攻防(五)之aircrack-ng破解WEP加密

系列文章 无线WiFi安全渗透与攻防(一)之无线安全环境搭建 无线WiFi安全渗透与攻防(二)之打造专属字典 无线WiFi安全渗透与攻防(三)之Windows扫描wifi和破解WiFi密码 无线WiFi安全渗透与攻防(四)之kismet的使用 aircrack-ng破解WEP加密 1.WEP介绍 其实我们平常在使用wifi的时…...

MySQL中事务的相关问题

事务 一、事务的概述: 1、事务处理(事务操作):保证所有事务都作为一个工作单元来执行,即使出现了故障,都不能改变这种执行方式。当在一个事务中执行多个操作时,要么所有的事务都被提交(commit…...

推荐算法再次踩坑记录

去年搞通了EasyRec这个玩意,没想到今年还要用推荐方面的东西,行吧,再来一次,再次踩坑试试。1、EasyRec训练测试数据下载:git clone后,进入EasyRec,然后执行:bash scripts/init.sh 将…...

STM32 (十五)MPU6050

简介前言一、MPU6050简介MPU6050是一款性价比很高的陀螺仪,可以读取X Y Z 三轴角度,X Y Z 三轴加速度,还有内置的温度传感器,在姿态解析方面应用非常广泛。下面是它在淘宝上的参数图产品尺寸产品参数产品原理图:二、硬…...

使用yarn,依赖报各种错误怎么办

使用 yarn^3.x 版本时,默认并不会安装包到 node_modules,因为 yarn3.x 是即插即用的,也就是说如果你下载过这个包,yarn只会生成一个 Png文件,然后将包的路径 link 到下载过的地方,这样可以省去很多时间。而…...

面试官:rem和vw有什么区别

"rem" 和 "vw"的区别 "rem" 和 "vw" 都是用于网页设计的CSS单位。 "rem" 是相对于根元素的字体大小来计算的单位,即相对于 "html" 标签的字体大小。例如,如果 "html" 标签的字…...

【GPT-4】GPT-4 相关内容总结

目录 ​编辑 官网介绍 GPT-4 内容提升总结 GPT-4 简短版总结 GPT-4 基础能力 GPT-4 图像处理 GPT-4 技术报告 训练过程 局限性 GPT-4 风险和应对措施 开源项目:OpenAI Evals 申请 GPT-4 API API的介绍以及获取 官网介绍 官网:GPT-4 API候…...

5.springcloud微服务架构搭建 之 《springboot集成Hystrix》

1.springcloud微服务架构搭建 之 《springboot自动装配Redis》 2.springcloud微服务架构搭建 之 《springboot集成nacos注册中心》 3.springcloud微服务架构搭建 之 《springboot自动装配ribbon》 4.springcloud微服务架构搭建 之 《springboot集成openFeign》 目录 1.项目…...

【工作中问题解决实践 七】SpringBoot集成Jackson进行对象序列化和反序列化

去年10月份以来由于公司和家里的事情太多,所以一直没有学习,最近缓过来了,学习的脚步不能停滞啊。回归正题,其实前年在学习springMvc的时候也学习过Jackson【Spring MVC学习笔记 五】SpringMVC框架整合Jackson工具,但是…...

香港服务器遭受DDoS攻击后如何恢复运行?

​  您是否发现流量异常上升?您的网站突然崩溃了吗?当您注意到这些迹象时,可能是在陷入了DDoS攻击的困境,因而,当开始考虑使用香港服务器时,也应该考虑香港服务器设备受DDoS攻击时,如何从中恢复。 在 DDoS 攻击香港…...

【Hive】配置

目录 Hive参数配置方式 参数的配置方式 1. 文件配置 2. 命令行参数配置 3. 参数声明配置 配置源数据库 配置元数据到MySQL 查看MySQL中的元数据 Hive服务部署 hiveserver2服务 介绍 部署 启动 远程连接 1. 使用命令行客户端beeline进行远程访问 metastore服务 …...

浏览器访问 AWS ECS 上部署的 Docker 容器(监听 80 端口)

✅ 一、ECS 服务配置 Dockerfile 确保监听 80 端口 EXPOSE 80 CMD ["nginx", "-g", "daemon off;"]或 EXPOSE 80 CMD ["python3", "-m", "http.server", "80"]任务定义(Task Definition&…...

可靠性+灵活性:电力载波技术在楼宇自控中的核心价值

可靠性灵活性:电力载波技术在楼宇自控中的核心价值 在智能楼宇的自动化控制中,电力载波技术(PLC)凭借其独特的优势,正成为构建高效、稳定、灵活系统的核心解决方案。它利用现有电力线路传输数据,无需额外布…...

React Native在HarmonyOS 5.0阅读类应用开发中的实践

一、技术选型背景 随着HarmonyOS 5.0对Web兼容层的增强,React Native作为跨平台框架可通过重新编译ArkTS组件实现85%以上的代码复用率。阅读类应用具有UI复杂度低、数据流清晰的特点。 二、核心实现方案 1. 环境配置 (1)使用React Native…...

基础测试工具使用经验

背景 vtune,perf, nsight system等基础测试工具,都是用过的,但是没有记录,都逐渐忘了。所以写这篇博客总结记录一下,只要以后发现新的用法,就记得来编辑补充一下 perf 比较基础的用法: 先改这…...

Vue ③-生命周期 || 脚手架

生命周期 思考:什么时候可以发送初始化渲染请求?(越早越好) 什么时候可以开始操作dom?(至少dom得渲染出来) Vue生命周期: 一个Vue实例从 创建 到 销毁 的整个过程。 生命周期四个…...

DeepSeek源码深度解析 × 华为仓颉语言编程精粹——从MoE架构到全场景开发生态

前言 在人工智能技术飞速发展的今天,深度学习与大模型技术已成为推动行业变革的核心驱动力,而高效、灵活的开发工具与编程语言则为技术创新提供了重要支撑。本书以两大前沿技术领域为核心,系统性地呈现了两部深度技术著作的精华:…...

Linux 下 DMA 内存映射浅析

序 系统 I/O 设备驱动程序通常调用其特定子系统的接口为 DMA 分配内存,但最终会调到 DMA 子系统的dma_alloc_coherent()/dma_alloc_attrs() 等接口。 关于 dma_alloc_coherent 接口详细的代码讲解、调用流程,可以参考这篇文章,我觉得写的非常…...

加密通信 + 行为分析:运营商行业安全防御体系重构

在数字经济蓬勃发展的时代,运营商作为信息通信网络的核心枢纽,承载着海量用户数据与关键业务传输,其安全防御体系的可靠性直接关乎国家安全、社会稳定与企业发展。随着网络攻击手段的不断升级,传统安全防护体系逐渐暴露出局限性&a…...

规则与人性的天平——由高考迟到事件引发的思考

当那位身着校服的考生在考场关闭1分钟后狂奔而至,他涨红的脸上写满绝望。铁门内秒针划过的弧度,成为改变人生的残酷抛物线。家长声嘶力竭的哀求与考务人员机械的"这是规定",构成当代中国教育最尖锐的隐喻。 一、刚性规则的必要性 …...

react菜单,动态绑定点击事件,菜单分离出去单独的js文件,Ant框架

1、菜单文件treeTop.js // 顶部菜单 import { AppstoreOutlined, SettingOutlined } from ant-design/icons; // 定义菜单项数据 const treeTop [{label: Docker管理,key: 1,icon: <AppstoreOutlined />,url:"/docker/index"},{label: 权限管理,key: 2,icon:…...