MySQL中的UNION和UNION ALL【简单易懂】

一、前言

  • UNION 和 UNION ALL 是 SQL 中用于合并多个查询结果集的关键字。

二、核心作用

  • 两者均用于将多个 SELECT 语句的结果集纵向合并(列结构需相同),但行为存在关键差异:

三、使用场景对比

  • 需要去重时:例如合并两个客户表且避免重复记录
sql 复制代码
SELECT customer_id FROM table1
UNION
SELECT customer_id FROM table2;
  • 需保留重复数据或追求性能时:例如统计日志数据时需保留所有条目
sql 复制代码
SELECT log_time FROM debug_logs
UNION ALL
SELECT log_time FROM error_logs;

四、关键注意事项

  • 列结构一致性
    • 列数量、对齐顺序必须严格一致。
    • 数据类型需兼容(如 VARCHAR 和 TEXT 可合并,但 INT 和 DATE 会报错)。
  • 排序与别名
    • 若需最终排序,仅在最后一个 SELECT 后加 ORDER BY:
sql 复制代码
SELECT name FROM employees
UNION ALL
SELECT name FROM contractors
ORDER BY name;  -- 整体排序
  • 列名以第一个 SELECT 语句指定的字段别名为准。

五、示例

  • student表结构如下:

  • score表结构如下:

1.UNION查询结果

2.UNION ALL查询结果

六、总结

  • UNION :适合数据去重场景,牺牲性能换取数据唯一性
  • UNION ALL :适合数据全量合并或性能敏感场景,尤其在大数据量时优先考虑。
  • 实际使用时需根据数据特性和业务需求权衡选择。
相关推荐
不剪发的Tony老师7 分钟前
CloudDM:一站式数据库开发管理工具
数据库
望获linux1 小时前
【实时Linux实战系列】Linux 内核的实时组调度(Real-Time Group Scheduling)
java·linux·服务器·前端·数据库·人工智能·深度学习
云宏信息1 小时前
【深度解析】VMware替代的关键一环:云宏ROW快照如何实现高频业务下的“无感”数据保护?
服务器·网络·数据库·架构·云计算·快照
怪兽20141 小时前
Redis常见性能问题和解决方案
java·数据库·redis·面试
hello_zzw1 小时前
docker部署MySQL主从服务集群
mysql·adb·docker
计算机学长felix1 小时前
基于SpringBoot的“中学信息技术课程教学网站”的设计与实现(源码+数据库+文档+PPT)_2025-10-17
数据库·spring boot·后端
长安城没有风2 小时前
从入门到精通【Redis】Redis 典型应⽤ --- 缓存 (cache)
数据库·redis·后端·缓存
学无止境w2 小时前
Redis在电商中的深度应用:商品缓存、秒杀锁、排行榜的实现与避坑指南
数据库·redis·缓存
象象翔2 小时前
Redis实战篇---添加缓存(店铺类型添加缓存需求)
数据库·redis·缓存
放弃幻想_2 小时前
S4和ECC或者不通CLIENT,不通HANA服务器互相取数
服务器·数据库·sap·abap·abap sap