UNION:合并查询结果,并去掉重复的行。

UNION ALL:合并查询结果,保留重复的行。

举例验证说明:

创建两个表:user_info 和 user_info_b,设置联合主键约束,联合主键的列是(user_id 和 user_name),并在两个表中分别插入数据。

SQL语句如下:

 1 create table user_info
2 (
3 user_id VARCHAR(3),
4 user_name VARCHAR(32) ,
5 user_gender VARCHAR(2) NOT NULL,
6 user_nation VARCHAR(7) NOT NULL,
7 user_info_affiliate VARCHAR(12) NOT NULL,
8 PRIMARY KEY (user_id,user_name)
9 )
10
11 create table user_info_b
12 (
13 user_id_b VARCHAR(3) ,
14 user_name_b VARCHAR(32) ,
15 user_gender_b VARCHAR(2) NOT NULL,
16 user_nation_b VARCHAR(7) NOT NULL,
17 user_info_b_affiliate VARCHAR(12) NOT NULL,
18 PRIMARY KEY (user_id_b,user_name_b)
19 )
20
21 insert into user_info
22 values ('001','秦始皇','男','中国','user_info')
23
24 insert into user_info
25 values ('002','刘邦','男','中国','user_info')
26
27 insert into user_info
28 values ('003','赵匡胤','男','中国','user_info')
29
30 insert into user_info
31 values ('004','成吉思汗','男','中国','user_info')
32
33 insert into user_info
34 values ('005','朱元璋','男','中国','user_info')
35
36 insert into user_info
37 values ('006','孙中山','男','中国','user_info')
38
39 insert into user_info
40 values ('007','武则天','女','中国','user_info')
41
42 insert into user_info
43 values ('008','孝庄太后','女','中国','user_info')
44
45
46 insert into user_info_b
47 values ('001','华盛顿','男','美国','user_info_b')
48
49 insert into user_info_b
50 values ('002','杰斐逊','男','美国','user_info_b')
51
52 insert into user_info_b
53 values ('003','林肯','男','美国','user_info_b')
54
55 insert into user_info_b
56 values ('004','肯尼迪','男','美国','user_info_b')
57
58 insert into user_info_b
59 values ('005','朴槿惠','女','韩国','user_info_b')
60
61 insert into user_info_b
62 values ('006','默克尔','女','德国','user_info_b')
63
64 insert into user_info_b
65 values ('007','撒切尓夫人','女','英国','user_info_b')
66
67 insert into user_info_b
68 values ('008','特蕾莎·梅','女','英国','user_info_b')

表创建好并插入数据后,我们查询下表里面的内容信息。

先查询user_info表,查询语句如下:

1 select * from user_info

查询结果:

再查询user_info_b表,查询语句如下:

1 select * from user_info_b

查询结果:

通过查询结果,我们看到,user_info表里有2条 user_gender = '女'的记录,user_info_b表里有4条 user_gender_b = '女'的记录。

现在有一个查询的任务,任务要求是:在两张表里查询女性用户的国籍,查询结果要求用性别和国籍两个字段展示。

好,我们写SQL语句,语句如下:

1  select user_gender,user_nation from user_info
2 where user_gender ='女'
3 UNION
4 select user_gender_b,user_nation_b from user_info_b
5 where user_gender_b ='女'

执行结果:

查询结果只有4条记录,但是,我们知道,两张表里女性记录共有2+4=6条,为什么会这样呢?

原因是:UNION操作,合并查询结果,并去掉重复的行。

在user_info表中,有2条 (user_gender = '女'  and user_nation = '中国')的记录 ;

在user_info_b表中,也有2条(user_gender = '女'  and user_nation = '英国')的记录

UNION查询后,去掉重复行保留1行,本来4条(user_gender = '女' )记录,保留为2条。

我们知道,实际上有6为女性用户,UNION查询结果只有4条,造成真实数据缺失,一般在这样的情况下,我们用UNION  ALL就能避免上述问题的产生。

上述语句修改如下:

1 select user_gender,user_nation from user_info
2 where user_gender ='女'
3 UNION ALL
4 select user_gender_b,user_nation_b from user_info_b
5 where user_gender_b ='女'

我们再来看下查询结果:

最后,我们再来复盘下 UNION 与UNION ALL的区别:

UNION:合并查询结果,并去掉重复的行。

UNION ALL:合并查询结果,保留重复的行。

UNION 与 UNION ALL 的区别的更多相关文章

  1. Union和Union All到底有什么区别

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

  2. union和union all的区别

    UNION 写一篇联合查询(把前后两个表的查询结果集合在前表中)首先有个为什么需要 相同记录数?? 记错了.应该是union两张表的查询字段数目要一致,字段类型要相似相同的数据类型,至少是相似,可转化 ...

  3. Oracle之Union与Union all的区别

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

  4. union与union all的区别

    首先说下union与join的区别 1.union是以行增加的方式,进行连接:join是以列增加的方式进行连接: 2.union连接查询的两个表的字段必须要一一对应,数目相等:join则没有要求,但是 ...

  5. C和C++中结构体(struct)、联合体(union)、枚举(enum)的区别

    C++对C语言的结构.联合.枚举 这3种数据类型进行了扩展. 1.C++定义的结构名.联合名.枚举名 都是 类型名,可以直接用于变量的声明或定义.即在C++中定义变量时不必在结构名.联合名.枚举名 前 ...

  6. Ms SQLServer中的Union和Union All的使用方法和区别

    Ms SQLServer中的Union和Union All的使用方法和区别 SQL UNION 操作符 UNION 操作符用于合并两个或多个 SELECT 语句的结果集. 请注意,UNION 内部的 ...

  7. union与union all 的区别

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

  8. Union 与 Union all 区别

    原创,请园长不要删 Sql查询统计时,很多时候用到了union 和 union all,union与union all的区别就是联合查询的时候union会去重,union all不会去重.本人用uni ...

  9. SQL Server函数​---Union与Union All的区别

    SQL Server函数---Union与Union All的区别 如果我们需要将两个select语句的结果作为一个整体显示出来,我们就需要用到union或者union all关键字.union(或称 ...

  10. Oracle中Union与Union All的区别(适用多个数据库)

    Oracle中Union与Union All的区别(适用多个数据库) 如果我们需要将两个select语句的结果作为一个整体显示出来,我们就需要用到union或者union all关键字.union(或 ...

随机推荐

  1. vue和react给我的感受

    以下纯属个人使用两个框架的感想和体会: 不知道你们是否有这种感觉~ 我vue和react都用过一段时间,但是vue给我感觉就是经常会忘记语法,需要对照文档才知道怎么写( 难不成是我没喝六个核桃的原因吗 ...

  2. CentOS系统Tomcat 8.5或9部署SSL证书

    本文档介绍了CentOS系统下Tomcat 8.5或9部署SSL证书的操作说明. 环境准备 操作系统:CentOS 7.6 64位 Web服务器:Tomcat 8.5或9 前提条件 已从阿里云SSL证 ...

  3. 利用window对象自带atob和btoa方法进行base64的编码和解码

    项目中一般需要将表单中的数据进行编码之后再进行传输到服务器,这个时候就需要base64编码 现在可以使用window自带的方法window.atob() 和  window.btoa()  方法进行 ...

  4. Abp 实现通过手机号注册用户

    前言 Abp 的 Identity 模块,实现了用户的管理,但是对于国内来讲,很多场景不能很好适配.比如:通过手机号进行注册的场景. Abp vnext Identity 以及 asp.net cor ...

  5. Windows原理深入学习系列-强制完整性检查

    这是[信安成长计划]的第 24 篇文章 0x00 目录 0x01 介绍 0x02 逆向分析 Win10_x64_20H2 0x03 总结 0x04 参考文章 最近因为一些事情,拖更了三个周,大家见谅啊 ...

  6. 移动安卓App+BurpSuite的渗透测试

    从Android 7.0及以上版本开始,安卓系统更改了信任用户安装证书的默认行为,用户安装的证书都是用户证书,因此不管是filddle还是burp,都是把他们的根证书安装到了用户证书,而有部分移动ap ...

  7. JS_简单的效果-鼠标移动、点击、定位元素、修改颜色等

    1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="U ...

  8. 基础的CSS描绘测试

    1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="U ...

  9. Spring 源码(5)BeanFactory使用的准备及自定义属性值解析器

    BeanFactory 使用前的准备 上一篇文章 https://www.cnblogs.com/redwinter/p/16165878.html 介绍了自定义标签的使用,完成了AbstractAp ...

  10. netty系列之:netty中的核心编码器base64

    目录 简介 netty codec的实现逻辑 netty中Base64的实现 netty中的base64编码和解码器 Base64Encoder Base64Decoder 总结 简介 我们知道数据在 ...