看完之后你就知道Union和Union All到底有什么区别

本文通过实际案例对比了SQL中的Union和UnionAll的区别。Union用于合并两个结果集,但会去除重复行并进行排序;而UnionAll同样合并结果集,但保留所有行,包括重复行,并且不对结果进行排序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

以前一直不知道Union和Union All到底有什么区别,今天来好好的研究一下,网上查到的结果是下面这个样子,可是还是不是很理解,下面将自己亲自验证:

Union:对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序;

Union All:对两个结果集进行并集操作,包括重复行,不进行排序;

下面进行简单的测试(因为是测试,所以sql代码写的很简单,没有什么很严格的规范,只是为了理解这两者之间的区别)

严格的标准写法应该先判断数据库是否存在,表是否存在等等约束

第一步,建库:

 Create database Test  
 go  
 
 use Test  
 go  

第二步,建表:

 Create table Table1  
 (  
 ​    id int not null,  
 ​    name varchar(20) not null  
 )  
   
 Create table Table2  
 (  
 ​    id int not null,  
 ​    name varchar(20) not null  
 )  

第三步,插入测试数据:

 Insert into Table1 values (1,'姚羽')  
 Insert into Table1 values (2,'边兵兵')  
 Insert into Table1 values (3,'袁磊')  
 
 Insert into Table2 values (1,'姚羽')  
 Insert into Table2 values (2,'柳春平')  
 Insert into Table2 values (3,'张永超')  
 Insert into Table2 values (4,'刘华健')  

第四步,测试开始:

select from Table1  
select from Table2  

执行两个表的查询结果如下

在这里插入图片描述

可以很容易的看到,上面插入的测试数据当中,有一条是重复的

那么我们 先看执行union 看看

select from Table1  
union
select from Table2  

在这里插入图片描述

再执行union all 看看

select from Table1  
union all
select from Table2  

在这里插入图片描述
总结union是拼接上下结果集只不过多了一个去重操作,union all就是上下两个结果集的拼接,仅作于拼接,不过还是要注意上下两个结果集的字段一定要一致,在MySQL中规范没有那么严格,可以随意拼接在一些国产数据库或者Oracle中如果上下结果集所对应的字段不一致会报错。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

一切如你i

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

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

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

打赏作者

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

抵扣说明:

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

余额充值