UNION和UNION ALL的区别

应用场景

如果我们需要将两个select语句的结果作为一个整体显示出来,我们就需要用到union或者union all关键字。union(或称为联合)的作用是将多个结果合并在一起显示出来。

区别

UNION:
(1)会自动压缩多个结果集合中的重复结果
(2)对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序;
UNION ALL:
(1)将所有的结果全部显示出来,不管是不是重复。
(2)对两个结果集进行并集操作,包括重复行,不进行排序。

实践

创表

首先我这里创建了两张表做演示,demo_a、demo_b
(demo_a)
在这里插入图片描述
(demo_b)
在这里插入图片描述

测试UNION

SELECT
	NAME
FROM
	demo_a
UNION
	SELECT
		NAME
	FROM
		demo_b

运行图

在这里插入图片描述
这里我们发现虽然两张表都有张三等其他重复的名称,但是union会做去重处理,所以只显示一条

测试UNION ALL

SELECT
	NAME
FROM
	demo_a
UNION ALL
	SELECT
		NAME
	FROM
		demo_b

运行图

在这里插入图片描述
我们发现虽然这两张表的数据同时显示了但是有重复数据,这也是UNION和UNION ALL的最大区别

总结

其实在UNION和UNION ALL的区别还有就是它们之间的性能也存在着区别,UNION需要做一个去重处理所以性能消耗肯定是比UNION ALL的性能消耗的要大些所以说使用场景也是看情况而定,比如说两张表的数据确保没有重复数据可以使用UNION ALL,有重复数据的情况下使用UNION

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

藤井大叔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值