SQL零基础入门教程,贼拉详细!贼拉简单! 速通数据库期末考!(九)

UNION ALL

UNION ALL 用于合并两个或多个 SELECT 语句的结果

请注意,UNION ALL 合并的每个 SELECT 语句必须是查询相同数量,相同数据类型的字段,且顺序也必须一致 。另外结果集中的列名总是等于 UNION ALL 中第一个 SELECT 语句中的列名

语法:

sql 复制代码
SELECT column_name(s) FROM table1
UNION ALL
SELECT column_name(s) FROM table2;

示例:

从students学生数据表查询理科三班和文科三班的学生id,学生姓名,班级

写法一:

使用我们之前的学习的 WHERE ... IN ... 方式:

sql 复制代码
SELECT id,name,clazz
FROM students
WHERE clazz IN ('理科三班','文科三班');

写法二:

使用 UNION ALL 结合两个 SELECT 查询的方式:

sql 复制代码
SELECT id,name,clazz
FROM students
WHERE clazz = '理科三班'
UNION ALL
SELECT id,name,clazz
FROM students
WHERE clazz = '文科三班';

观察这两种写法的结果,写法一的结果中理科三班和文科三班的数据行是交错分布的,但是写法二的结果明显是分别从students表中查询出两部分结果,再纵向拼接而成的,这也是使用 UNION ALL的前提是每个SELECT查询的字段完全一致的原因。

带有 ORDER BY 的 UNION ALL

思考一个问题,如果我希望在 UNION ALL 后的结果中进行排序操作,那是不是每个 SELECT 语句都要加 ORDER BY 呢?

来测试一下:

从students学生数据表查询理科三班和文科三班的学生id,学生姓名,班级,并且按学生ID升序排列

错误写法:

sql 复制代码
SELECT id,name,clazz
FROM students
WHERE clazz = '理科三班'
ORDER BY id
UNION ALL
SELECT id,name,clazz
FROM students
WHERE clazz = '文科三班'
ORDER BY id;

很明显,这种写法是不行的,报错 Incorrect usage of UNION and ORDER BY,意思为 不正确地使用UNION和ORDER BY

正确写法:

sql 复制代码
SELECT id,name,clazz
FROM students
WHERE clazz = '理科三班'
UNION ALL
SELECT id,name,clazz
FROM students
WHERE clazz = '文科三班'
ORDER BY id;

使用UNION命令时需要注意,只能在最后使用一个ORDER BY命令,是将两个查询结果合在一起之后,再进行排序!

UNION

UNION 同样用于合并两个或多个 SELECT 语句的结果 。与 UNION ALL 唯一不同的地方在于 UNION 对查询结果进行去重操作,对所有重复出现的相同数据行只保留一行结果,其用法与 UNION ALL 完全一致。

此处不再过多赘述,大家自己尝试一下即可。

本专栏将持续更新,对数据库SQL感兴趣的同学可以关注一下,谢谢!

相关推荐
努力成为一个程序猿.12 分钟前
【Flink】FlinkSQL-动态表和持续查询概念
大数据·数据库·flink
kali-Myon30 分钟前
NewStarCTF2025-Week4-Web
sql·安全·web安全·php·ctf·ssti·ssrf
摇滚侠34 分钟前
Spring Boot3零基础教程,Reactive-Stream 四大核心组件,笔记106
java·spring boot·笔记
毕设十刻1 小时前
基于Vue的学分预警系统98k51(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
✎ ﹏梦醒͜ღ҉繁华落℘1 小时前
FreeRTOS学习笔记(应用)-- 各种 信号量的应用场景
笔记·学习
星星火柴9361 小时前
笔记 | C++面向对象高级开发
开发语言·c++·笔记·学习
BeingACoder1 小时前
【SAA】SpringAI Alibaba学习笔记(一):SSE与WS的区别以及如何注入多个AI模型
java·笔记·学习·saa·springai
liliangcsdn2 小时前
如何利用约束提示优化LLM在问题转sql的一致性
数据库·sql
安全不再安全2 小时前
免杀技巧 - 早鸟注入详细学习笔记
linux·windows·笔记·学习·测试工具·web安全·网络安全
BreezeJuvenile2 小时前
外设模块学习(8)——HC-SR04超声波模块(STM32)
stm32·单片机·嵌入式硬件·学习·超声波测距模块·hc-sr04