mysql中的union和union all的区别-mysql教程
UNION 与 UNION ALL:MySQL 中两个集合操作符的差异
在 MySQL 中,UNION 和 UNION ALL 是用于组合两个或多个表中数据的强大操作符。然而,它们之间存在着重要的差异。
UNION
- 仅返回结果集中唯一的行。
- 在将行添加到结果集之前,会按升序对行进行排序。
- 消除重复的行,即使它们来自不同的表。
UNION ALL
- 返回结果集中所有行,包括重复行。
- 不会对行进行排序。
- 保留重复行,即使它们来自不同的表。
选择使用哪种操作符
选择 UNION 或 UNION ALL 取决于特定需求:
- 如果需要消除重复行,请使用 UNION。
- 如果需要保留所有行,包括重复行,请使用 UNION ALL。
- 如果需要对结果进行排序,请使用 UNION。
- 如果排序无关紧要,请使用 UNION ALL。
示例
考虑以下两个表:
表 A:
Student_ID | Student_Name |
---|---|
1 | John |
3 | Mary |
表 B:
Student_ID | Student_Name |
---|---|
3 | Mary |
5 | Bob |
使用 UNION 操作符:
SELECT * FROM A UNION SELECT * FROM B;
登录后复制
结果:
| Student_ID | Student_Name | |---|---| | 1 | John | | 3 | Mary | | 5 | Bob |
登录后复制
使用 UNION ALL 操作符:
SELECT * FROM A UNION ALL SELECT * FROM B;
登录后复制
结果:
| Student_ID | Student_Name | |---|---| | 1 | John | | 3 | Mary | | 3 | Mary | | 5 | Bob |
登录后复制