mysql--union与union all的区别
最近做项目有一需求,需要把两张表的数据进行叠加,用到union和union all两个操作符,以下讲解这两个操作符的区别。
源数据:
使用union和union all的前提条件, 合并集合的结果有相同个数的列,并且每个列的类型是一样的。列的顺序必须相同;
union的用法:
union操作符用于合并两个或多个 SELECT 语句的结果集。
SELECT * FROM studentScores_Test01UNION SELECT * FROM studentScores_Test
结果:
对比上图两个表中源数据,发现两张表数据相同,union之后,数据为一张表数据,说明union之后,会对数据进行去重,但并没有排序;
另外,UNION 结果集中的列名总是等于 UNION 中第一个 SELECT 语句中的列名。
union all用法:
union all操作符用于合并两个或多个 SELECT 语句的结果集。
SELECT * FROM studentScores_Test01 UNION ALL SELECT * FROM studentScores_Test;
结果:
通过结果发现:union all 不会对结果进行去重。