Union和Union All到底有什么区别

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

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

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

 

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

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

第一步,建库:

  1. Create database Test  
  2. go  
  3.   
  4. use Test  
  5. go  


第二步,建表:

  1. Create table Table1  
  2. (  
  3.     id int not null,  
  4.     name varchar(20) not null  
  5. )  
  6.   
  7. Create table Table2  
  8. (  
  9.     id int not null,  
  10.     name varchar(20) not null  
  11. )  

 

第三步,插入测试数据:

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


第四步,测试开始:

  1. select * from Table1  
  2. select * from Table2  

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


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

那么我们  先看执行union 看看

  1. select * from Table1  
  2. union   
  3. select * from Table2  


 

再执行union  all 看看

  1. select * from Table1  
  2. union all  
  3. select * from Table2  

 

 

相信到此时,应该明白了union  和 union all 的区别了,  我以前也一直没搞清楚,这次看视频,就终于搞清楚了

`UNION ALL` `UNION` 都是用来连接两个或更多的 `SELECT` 语句的结果集的操作符,但是它们之间有一些重要的区别。 ### 主要区别在于处理重复数据方面: - **去除重复项**:`UNION` 默认会先对所有结果进行排序然后去掉其中完全相同的行,这意味着它只保留唯一的数据组合。如果你的数据集中存在很多重复的记录,则可能会导致较长的时间开销来进行这样的操作; - **保持全部内容**:而相比之下,`UNION ALL` 则不会做这一步骤——它直接把来自各个查询的所有行合并在一起输出,包括那些重复的部分。因此通常来说它的执行效率要比普通形式高得多,特别是在大规模数据量下尤为明显。 ### 其他需要注意的地方还包括: - **排序规则**:由于 `UNION` 操作涉及到了内部排重的过程,默认情况下会对整个结果集按照某些条件自动排列;相反地,除非明确指定 otherwise ,否则利用 `UNION ALL` 得出的结果并不会自带特定顺序; - **应用场景的选择**:当你确定所联接的不同表之间的交集为空集、或者根本不在乎是否含有副本的时候应该优先选用速度更快且资源消耗更低廉的 `UNION ALL`. 只有当确实需要消除冗余信息时才考虑使用标准版 union 进行进一步筛选清理工作. 总之,在大多数情况下建议尽可能多地运用 `UNION ALL`, 因为其能提供更高效的查询体验并且在绝大多数业务场景中已经足够满足需求了.
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值