我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

带例子详解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内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

sql中的union和union all的区别

union仅返回唯一行,而union all包含重复行;union在合并前去重,union all不对行去重。SQL 中 UNION 和 UNION ALL 的区别UNION 和 UNION ALL 都是用于合并两个或多个表中的行的 SQ
sql中的union和union all的区别
2024-05-02

MySQL中union和unionall区别

union:对多个结果集进行并集操作,不包括重复行,同时进行排序。union all:对多个结果集进行并集操作,包括重复行,不进行排序。查询部门小于30号的员工信息,和部门大于20小于40号的员工信息。①.先查询部门小于30号的员工信
2023-04-23

oracle中union和union all区别

oracle 中 union 和 union all 的区别在于处理重复行的方式。union 删除重复行,仅返回不同行;union all 保留所有行,包括重复行。Oracle 中 UNION 和 UNION ALL 的区别本质区别:U
oracle中union和union all区别
2024-04-30

mysql中的union和union all的区别

mysql中的union和union all集合操作符之间的差异:union返回唯一行,而union all返回所有行,包括重复行。union按升序对结果集排序,而union all不排序。选择union消除重复行,而选择union all
mysql中的union和union all的区别
2024-04-26

mysql中union与union all的区别

UNION用的比较多union all是直接连接,取到得是所有值,记录可能有重复 union 是取唯一值,记录没有重复 1、UNION 的语法如下: [SQL 语句 1] UNION [SQL 语句 2]2、UNION ALL
mysql中union与union all的区别
2018-11-29

SQL中的union和union all怎么使用

这篇文章主要介绍了SQL中的union和union all怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇SQL中的union和union all怎么使用文章都会有所收获,下面我们一起来看看吧。概念MyS
2023-03-01

简单了解MySQL union all与union的区别

union 是对数据进行并集操作,不包括重复行,同时进行默认排序Union all 是对数据进行并集操作,包括重复行,不进行排序举例说明: 创建数据库表:CREATE TABLE `t_demo` (`id` int(32) NOT NUL
2022-05-19

简单聊一聊SQL中的union和union all

目录概念基础语法使用技巧区别总结概念mysql UNION 操作符用于连接两个以上的 SELECT 语句的结果组合到一个结果集合中。多个 SELECT 语句会删除重复的数据。UNION 操作符选取不同的值,如果允许得到重复的值,可以使用
2023-02-22

简单聊一聊SQL中的union和union all

在写SQL的时候,偶尔会用到两个表的数据结合在一起返回的,就需要用到UNION和UNIONALL,这篇文章主要给大家介绍了关于SQL中union和union all的相关资料,需要的朋友可以参考下
2023-02-22

sql中union和union all的用法是什么

这篇文章给大家介绍sql中union和union all的用法是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。如果我们需要将两个select语句的结果作为一个整体显示出来,我们就需要用到union或者union a
2023-06-28

sql中union和join的区别

sql 中 union 与 join 的区别:union 合并相同结构表的行,消除重复项;join 基于条件连接表的行,允许不同结构。union 性能通常比 join 快,但需要相同结构表;join 灵活但性能可能较低。SQL 中 UNIO
sql中union和join的区别
2024-05-02

数据库中join和union的区别是什么

Join和Union是数据库中常用的两种操作,它们有不同的作用和用法。Join:Join是用于将两个或多个表中的数据进行关联的操作。Join操作是基于表之间的关联条件,将符合条件的行进行匹配组合,生成一个新的结果集。Join操作可以根据
数据库中join和union的区别是什么
2024-03-04

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录