带例子详解Sql中Union和Union ALL的区别

 更新时间:2022年09月25日 11:22:42   作者:我赢了算我输  
这篇文章主要介绍了带例子详解Sql中Union和Union ALL的区别,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下

前言

一段时间没有用Union和Union,再用的时候忘了怎么用了。。。所以做一篇文章来记录自己学Union和Union的经历。

提前准备

在Sql Server 创建两张表,下面是创建表sql语句。

create table Student1(
   Id varchar(50) not null,
   Name varchar(50) not null,
   Age int not null
)
create table Student2(
   Id varchar(50) not null,
   Name varchar(50) not null,
   Age int not null
)
insert into Student1 values(1,'学生A',13)
insert into Student1 values(2,'学生B',13)
insert into Student1 values(3,'学生C',13)
insert into Student1 values(4,'学生D',13)

insert into Student2 values(1,'学生A',13)
insert into Student2 values(2,'学生E',13)
insert into Student2 values(3,'学生F',13)
insert into Student2 values(4,'学生D',13)

创建两张一摸一样的表并插入数据。

测试

UNION:合并两个或三个以上的Select语句的结果集,合并之后的结果集不包含重复的数

UNION ALL:合并两个或三个以上的Select语句的结果集,合并之后的结果集可以包含重复的数 。

可以看出,Union和Union All 的区别在于是否“包含重复数”,而重复数又指的是什么呢?当出现一条数据与另一条数据的所有列数据完全相同的情况,那么就称这条数据为重复数,下面拿例子来演示

Union

select * from Student1
union
select * from Student2

结果:

id为2、3的出现了两条,是因为Student1 id为2的Name列数据和Student2 id为2的Name列数据不同 (Student1为学生B,Student为学生E),并不能算重复数。
id为1、4、5只出现一次,是因为Student1和Student2中id为1、4、5的列数据完全相同,所以算重复数

Union ALL

select * from Student1
union ALL
select * from Student2

union all 就无需顾及到重复数,直接把两个表的结果集合并一起展示就OK了。
除此之外,还有几种情况

1.当表Student1和表Student2字段数量不同的情况下,使用Union和Union ALL

create table Student3(
   Id varchar(50) not null,
   Name varchar(50) not null,
   Age int not null
)
create table Student4(
   Id varchar(50) not null,
   Name varchar(50) not null
)

insert into Student3 values(1,'学生A',13)
insert into Student3 values(2,'学生B',13)
insert into Student3 values(3,'学生C',13)
insert into Student3 values(4,'学生D',13)

insert into Student4 values(1,'学生A')
insert into Student4 values(2,'学生E')
insert into Student4 values(3,'学生F')
insert into Student4 values(4,'学生D')

Student3 和Student4的字段不一样,Student3表比Student4表多一个Age字段

Union

select * from Student3
union
select * from Student4

Union All

select * from Student3
union ALL
select * from Student4

测试结果显示:只有当涉及的几个表的列具有相同的数量,才能使用Union和UnionALL

2.当表A和表B的列相同,但是列名不一致的情况,使用Union和Union ALL

create table Student3(
   Id varchar(50) not null,
   NameTest varchar(50) not null,
   Age int not null
)
create table Student4(
   Id varchar(50) not null,
   Name varchar(50) not null,
   Age int not null
)

insert into Student3 values(1,'学生A',13)
insert into Student3 values(2,'学生B',13)
insert into Student3 values(3,'学生C',13)
insert into Student3 values(4,'学生D',13)

insert into Student4 values(1,'学生A',13)
insert into Student4 values(2,'学生B',13)
insert into Student4 values(3,'学生C',13)
insert into Student4 values(4,'学生D',13)

这里Student3的第二个栏位是NameTest,而Student4第二个栏位是Name,Student3和Student4的数据一样。

union

select * from Student3
union 
select * from Student4

Union All

select * from Student3
union  ALL
select * from Student4

测试结果显示:如果当列数量一样,列名不相同,那么列名优先显示先执行Select语句的结果集的列名

最后

上面进行了对 “重复数”、“列数不同”、“列数相同,但列名不相同”进行测试,我得出了自己认为的答案

到此这篇关于带例子详解Sql中Union和Union ALL的区别的文章就介绍到这了,更多相关Sql Union和Union ALL内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL连接异常报10061错误问题解决

    MySQL连接异常报10061错误问题解决

    这篇文章主要介绍了MySQL连接异常报10061错误问题解决,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • MySQL5.7主从复制详细配置教程

    MySQL5.7主从复制详细配置教程

    这篇文章主要介绍了MySQL5.7主从复制详细配置教程的相关资料,需要的朋友可以参考下
    2022-11-11
  • Mysql数据库设计三范式实例解析

    Mysql数据库设计三范式实例解析

    这篇文章主要介绍了Mysql数据库设计三范式实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-04-04
  • Mac 下 MySQL5.7.22的安装过程

    Mac 下 MySQL5.7.22的安装过程

    这篇文章主要介绍了Mac 下 MySQL5.7.22的安装过程,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2018-05-05
  • MySQL参数优化信息参考(my.cnf参数优化)

    MySQL参数优化信息参考(my.cnf参数优化)

    下面针对一些参数进行说明,当然还有其它的设置可以起作用,取决于你的负载或硬件:在慢内存和快磁盘、高并发和写密集型负载情况下,你将需要特殊的调整
    2024-07-07
  • Mysql如何查询字符串开头的数据

    Mysql如何查询字符串开头的数据

    这篇文章主要介绍了Mysql如何查询字符串开头的数据问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-07-07
  • 常见php与mysql中文乱码问题解决办法

    常见php与mysql中文乱码问题解决办法

    MySQL对中文的支持程度还是很有限的,尤其是新手,但凡出现乱码问题,就会头大。
    2014-09-09
  • MYSQL  group by 有哪些注意事项

    MYSQL  group by 有哪些注意事项

    这篇文章主要介绍了MYSQL  group by 有哪些注意事项,比如我们不能在 group by 之后添加 where 查询语句,更多相关分享,需要的朋友可以参考下面文章内容
    2022-07-07
  • MySQL中执行计划explain命令示例详解

    MySQL中执行计划explain命令示例详解

    这篇文章主要给大家介绍了关于MySQL中执行计划explain命令的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用explain命令具有一定的参考学习价值,需要的朋友们下面说来一起学习学习吧
    2018-05-05
  • MySQL优化中B树索引知识点总结

    MySQL优化中B树索引知识点总结

    在本文里我们给大家整理了关于MySQL优化中B树索引的相关知识点内容,需要的朋友们可以学习下。
    2019-02-02

最新评论