Java技术债务Java技术债务

  •  首页
  •  分类
  •  归档
  •  标签
  • 博客日志
  • 资源分享
  •  友链
  •  关于本站
注册
登录

浅谈SQL中的union和union all

MySQL,面经

文章目录

  • 概念
  • 基础语法
  • 使用技巧
  • 区别
  • 总结

概念

MySQL UNION 操作符用于连接两个以上的 SELECT 语句的结果组合到一个结果集合中。多个 SELECT 语句会删除重复的数据。

UNION 操作符选取不同的值,如果允许得到重复的值,可以使用 UNION ALL

基础语法

-- union
SELECT column_name(s) FROM table1
UNION
SELECT column_name(s) FROM table2;

-- union all
SELECT column_name(s) FROM table1
UNION ALL
SELECT column_name(s) FROM table2;

注意: UNION 内部的每个 SELECT 语句必须拥有相同数量的列

列也必须拥有相似的数据类型

每个 SELECT 语句中的列的顺序必须相同

使用技巧

我们发现我们用 UNION 得到的结果都是必须是相同的,这就不得不提 in 和 or 这两个关键字了

-- in
select * from users 
where name in ('sbc', 'bhy');

-- or
select * from users
where name = 'sbc' or name = 'bhy';

select * from users
where name = 'sbc' or tel = '123456';

-- union
select * from users
where name = 'sbc'
union
select * from users
where name = 'bhy';

select * from users
where name = 'sbc'
union
select * from users
where tel = '123456';

通过在用户表(users)这几个select语句中我们比较一下

如果我们想要名字为 sbc 或者 bhy 的用户我们可以用in、or和union都可以实现

如果在较大的数据量下差距就会有明显的差距,如果 name 字段存在索引,这几种方法都是不分上下的;可是如果像 or 写法的第二种情况,那数据库都会去找两个字段各自的索引吗,答案不是的,数据库只会寻找一个字段的索引,而另一个字段就需要全局查询

这样遇到较大的数据量就会耗费大量的时间,但是 union 方法的第二种方法就会引用两次索引。

区别

  • union :对两个结果集进行并集操作,不包括重复行,相当于distinct,同时进行默认规则的排序
  • union all:对两个结果集进行并集操作,包括重复行,即所有的结果全部显示,不管是不是重复;

tips union all只是合并查询结果,并不会进行去重和排序操作,在没有去重的前提下,使用union all的执行效率要比union高

总结

如果遇到没有索引的表或者只对单个字段进行筛选,其实推荐使用 or 和 in ,看上去优雅简洁

如果遇到多个索引列的情况,还是推荐使用 union 和 union all

概念

MySQL UNION 操作符用于连接两个以上的 SELECT 语句的结果组合到一个结果集合中。多个 SELECT 语句会删除重复的数据。

UNION 操作符选取不同的值,如果允许得到重复的值,可以使用 UNION ALL

基础语法

-- union
SELECT column_name(s) FROM table1
UNION
SELECT column_name(s) FROM table2;

-- union all
SELECT column_name(s) FROM table1
UNION ALL
SELECT column_name(s) FROM table2;

注意: UNION 内部的每个 SELECT 语句必须拥有相同数量的列

列也必须拥有相似的数据类型

每个 SELECT 语句中的列的顺序必须相同

使用技巧

我们发现我们用 UNION 得到的结果都是必须是相同的,这就不得不提 in 和 or 这两个关键字了

-- in
select * from users 
where name in ('sbc', 'bhy');

-- or
select * from users
where name = 'sbc' or name = 'bhy';

select * from users
where name = 'sbc' or tel = '123456';

-- union
select * from users
where name = 'sbc'
union
select * from users
where name = 'bhy';

select * from users
where name = 'sbc'
union
select * from users
where tel = '123456';

通过在用户表(users)这几个select语句中我们比较一下

如果我们想要名字为 sbc 或者 bhy 的用户我们可以用in、or和union都可以实现

如果在较大的数据量下差距就会有明显的差距,如果 name 字段存在索引,这几种方法都是不分上下的;可是如果像 or 写法的第二种情况,那数据库都会去找两个字段各自的索引吗,答案不是的,数据库只会寻找一个字段的索引,而另一个字段就需要全局查询

这样遇到较大的数据量就会耗费大量的时间,但是 union 方法的第二种方法就会引用两次索引。

区别

  • union :对两个结果集进行并集操作,不包括重复行,相当于distinct,同时进行默认规则的排序
  • union all:对两个结果集进行并集操作,包括重复行,即所有的结果全部显示,不管是不是重复;

tips union all只是合并查询结果,并不会进行去重和排序操作,在没有去重的前提下,使用union all的执行效率要比union高

总结

如果遇到没有索引的表或者只对单个字段进行筛选,其实推荐使用 or 和 in ,看上去优雅简洁

如果遇到多个索引列的情况,还是推荐使用 union 和 union all

完
  • 本文作者:Java技术债务
  • 原文链接: https://cuizb.top/myblog/article/1676991288
  • 版权声明: 本博客所有文章除特别声明外,均采用 CC BY 3.0 CN协议进行许可。转载请署名作者且注明文章出处。
阅读全文
Java技术债务

Java技术债务

Java技术债务
Java技术债务
热门文章
  1. ClickHouse使用过程中的一些查询优化(六)2003
  2. MySQL数据库被攻击,被删库勒索,逼迫我使出洪荒之力进行恢复数据764
  3. MySQL主从同步原理458
  4. 线程池的理解以及使用414
  5. Spring Cloud Gateway整合nacos实战(三)409
分类
  • Java
    30篇
  • 设计模式
    27篇
  • 数据库
    20篇
  • Spring
    18篇
  • MySQL
    13篇
  • ClickHouse
    11篇
  • Kubernetes
    10篇
  • Redis
    9篇
  • Docker
    8篇
  • SpringBoot
    7篇
  • JVM
    6篇
  • Linux
    5篇
  • Spring Cloud
    5篇
  • 多线程
    5篇
  • Netty
    4篇
  • Kafka
    4篇
  • 面经
    4篇
  • Nginx
    3篇
  • JUC
    3篇
  • 随笔
    2篇
  • 分布式
    1篇
  • MyBatis
    1篇
  • 报错合集
    1篇
  • 生活记录
    1篇
  • 源码
    1篇
  • 性能优化
    1篇

最新评论

  • MySQL数据库被攻击,被删库勒索,逼迫我使出洪荒之力进行恢复数据2022-05-06
    Java技术债务:@capture 一起探讨学习,服务器被黑很正常,及时做好备份以及做好防护
  • MySQL数据库被攻击,被删库勒索,逼迫我使出洪荒之力进行恢复数据2022-04-13
    capture:我的刚上线两天,网站里就两篇文章也被攻击了,纳闷
  • Java常用集合List、Map、Set介绍以及一些面试问题2022-01-18
    Java技术债务:HashSet和TreeSet 相同点:数据不能重复 不同点: 1、底层存储结构不同; HashSet底层使用HashMap哈希表存储 TreeSet底层使用TreeMap树结构存储 2、唯一性方式不同 HashSet底层使用hashcode()和equal()方法判断 TreeSet底层使用Comparable接口的compareTo判断的 3、HashSet无序,TreeSet有序
  • undefined2021-12-14
    Java技术债务:如果不指定线程池,CompletableFuture会默认使用ForkJoin线程池,如果同一时间出现大量请求的话,会出现线程等待问题,建议使用自定义线程池。。。
  • undefined2021-12-02
    you:很好,对于小白相当不错了,谢谢
  • CSDN
  • 博客园
  • 程序猿DD
  • 纯洁的微笑
  • spring4all
  • 廖雪峰的官方网站
  • 猿天地
  • 泥瓦匠BYSocket
  • crossoverJie
  • 张先森个人博客
  • 越加网

© 2021-2022 Java技术债务 - Java技术债务 版权所有
总访问量 0 次 您是本文第 0 位童鞋
豫ICP备2021034516号
Java技术债务 豫公网安备 51011402000164号

微信公众号

Java技术债务
Java技术债务

专注于Spring,SpringBoot等后端技术探索

以及MySql数据库开发和Netty等后端流行框架学习

日志
分类
标签
RSS

有不足之处也希望各位前辈指出