简单聊一聊SQL中的union和union all
作者:Java技术债务 发布时间:2024-01-18 00:17:17
标签:sql,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高
来源:https://blog.csdn.net/qq_40124555/article/details/129152128


猜你喜欢
- 安装jieba库教程jieba库是一款优秀的 Python 第三方中文分词库,jieba 支持三种分词模式:精确模式、全模式和搜索引擎模式,
- 参照网上资料在CentOS6.8服务器上使用cmake安装了MySQL5.7.18,安装过程中遇到了各种各样的问题,大多问题在网上都能找到解
- 使用vs2010连接mysql 数据库,1.装连接驱动,使用Connector/Net 连接驱动!下载地址:http://dev.mysql
- 这篇文章主要介绍了python学习之第三方包安装方法,最近在学习QQ空间、微博(爬虫)模拟登录,都涉及到了RSA算法。这样需要下一个RSA包
- 开放平台的API接口调用需要限制其频率,以节约服务器资源和避免恶意的频繁调用使用自定义频率限制组件:utils/thottle.pyclas
- pydantic是一个Python的数据验证和转换库,它的特点是轻量、快速、可扩展、可配置。笔者常用的用于数据接口schema定义与检查。具
- 1、程序执行代码:#Author by Andy#_*_ coding:utf-8 _*_import os,sys,timeBase_di
- 前言:关于数据库范式,时常有听说过,一直没有详细去了解。一般数据库书籍或数据库课程会介绍范式相关内容,范式也经常出现在数据库考试题目中。不清
- 本文实例讲述了python实现的简单RPG游戏流程。分享给大家供大家参考。具体如下:#RPGrpg = Truewhp = 100mahp
- ImageField的使用笔记今天完善作业写的订单系统,主要是给每一个菜品增加图片,看起来美观一些,但是没想到这个小小的需求花了我一天时间,
- PDOStatement::fetchColumnPDOStatement::fetchColumn — 从结果集中的下一行返回单独的一列。
- 本文实例为大家分享了python绘制温度变化雷达图的具体代码,供大家参考,具体内容如下假设某天某地每三个小时取样的气温为针对温度变化趋势绘制
- 最近将Pytorch程序迁移到GPU上去的一些工作和思考环境:Ubuntu 16.04.3Python版本:3.5.2Pytorch版本:0
- 从matplotlib工具栏源码探析一(禁用工具栏、默认工具栏和工具栏管理器三种模式的差异)一文可知matplotlib内置实现了多个工具项
- sql中timestamp和datetime的转换互相转换说明:将datetime转换为timestamp格式,使用UNIX_TIMESTA
- DATE_ADD(date,INTERVAL expr type) DATE_SUB(date,INTERVAL expr type)这些函
- 前言在vue里,组件之间的作用域是独立的,父组件跟子组件之间的通讯可以通过prop属性来传参,但是在兄弟组件之间通讯就比较麻烦了。比如A组件
- 在程序中,有多种方法进行强制类型转换。本博文将介绍一个非常常用的方法:to()方法。我们通常使用它来进行GPU和CPU的类型转换,但其实也可
- 页面加载loading效果, 这个挺好玩的!用setTimeout实现的!可以和服务端整合弄一些生成HTML或者上传文件等应用!
- 很多DBA目前还停留在Oracle 9i或者10g,究其原因有可能是Oracle 11g的价格问题。本文将为大家讲解在Windows 7下安