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 :适合数据全量合并或性能敏感场景,尤其在大数据量时优先考虑。
  • 实际使用时需根据数据特性和业务需求权衡选择。
相关推荐
NineData10 小时前
NineData 迁移评估功能正式上线
数据库·dba
NineData15 小时前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
阿里云大数据AI技术15 小时前
用 SQL 调大模型?Hologres + 百炼,让数据开发直接“对话”AI
sql·llm
赵渝强老师17 小时前
【赵渝强老师】PostgreSQL中表的碎片
数据库·postgresql
全栈老石21 小时前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码
倔强的石头_2 天前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou643 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北3 天前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤4 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12025 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql