Union 与 Union all 区别
原创,请园长不要删
Sql查询统计时,很多时候用到了union 和 union all,union与union all的区别就是联合查询的时候union会去重,union all不会去重。本人用union all,主要用来统计多个不相关的表的数据汇总,用的次数很多,所以有点心得,记录下来,分享一下。
比如 :有两个店,一个叫店A,一个叫店B,下面是表数据
2014-01-16 |
小张 |
||
2 |
3000 |
2014-01-15 |
小李 |
3 |
4000 |
2014-01-14 |
小样 |
2014-01-15 |
||
2 |
3000 |
2014-01-16 |
现在有个需求,将店A表中的"收入" 和 店B 表中的"现金"统一列出来,那么我们的sql就是
Select amount as money from table_a union all select cash as money from table_b
结果就是
结果 |
Money |
2000 |
3000 |
4000 |
2000 |
3000 |
如果我们去掉union all中的all,那么结果就是
结果 |
Money |
2000 |
3000 |
4000 |
这里将会将2000这个重复的结果去掉。
如果我将其他不同的字段也加到查询中来,我们来对比一下
Select amount as money ,create_date as date from table_a union all select cash as money ,create_date as date from table_b
money |
date |
2000 |
2014-01-16 |
3000 |
2014-01-15 |
4000 |
2014-01-14 |
2000 |
2014-01-15 |
3000 |
2014-01-16 |
Select amount as money ,create_date as date from table_a union select cash as money ,create_date as date from table_b
money |
date |
2000 |
2014-01-16 |
3000 |
2014-01-15 |
4000 |
2014-01-14 |
2000 |
2014-01-15 |
3000 |
2014-01-16 |
从结果可以看出,如果不是两个字段同时相等,union 是不会去掉重复一个字段的,如果我想去掉重复的,怎么办,目前我只能提供的就是方法就是去掉重复结果,就只查那个字段。
注意!
1 如果是多个表查询,两个以上的表进行union all查询,如果全是union all,那还没什么问题,但中间如果出现了任意一个union,那结果全部都会去重!
如果两个表union查询的时候,缺字段,怎么办?比如现在将店A,店B的所有"收入"和"操作员"全部列出来,这里店B表没有操作员这个字段,我这样操作,做个假的代替
Select amount as money ,create_date as date ,USER_name as name from table_a
union all
select cash as money ,create_date as date,'店B员工' as name from table_b
最后的结果就是这样
money |
date |
name |
2000 |
2014-01-16 |
小张 |
3000 |
2014-01-15 |
小李 |
4000 |
2014-01-14 |
小样 |
2000 |
2014-01-15 |
店B员工 |
3000 |
2014-01-16 |
店B员工 |
虽然这种办法不是很好,但确能实际解决问题,能解决问题的方法就是好方法。所以,一个小小的union关键字也还是有很多地方值得我们研究的。
2 union与order by一起使用会出现错误
比如这条语句:
select amount as money ,create_date as date ,USER_name as name from table_a ORDER BY create_date desc
union all
select cash as money ,create_date as date,'店B员工' as name from table_b
执行的时候就会报
[Err] 1221 - Incorrect usage of UNION and ORDER BY
其实报这个错也不难理解,在测试表中,首先union all就是指这两个表查询的结果联合组成的结果集,两个结果集都是相同的字段,如果一个结果集排序,那另一个集合是否也应该排序?就算排序了,本身两个就是各自排各自的序,然后汇总。而我们需要的是整体排序的结果,显然这不是我们期望的结果。所以各自排序根本就没意义。
但如果我有这样的需求,是否能排序了,答案是肯定的
我们知道,sql执行的顺序是先查from后面的表,再查where条件,再是select 字段,排序是最后自执行,所以当查出来所有结果以后我们再统一排序,那样就达到我们期望的结果了
select amount as money ,create_date as date ,USER_name as name from table_a
union all
select cash as money ,create_date as date,'店B员工' as name from table_b
ORDER BY date asc
money |
date |
name |
4000 |
2014-01-14 |
小样 |
3000 |
2014-01-15 |
小李 |
2000 |
2014-01-15 |
店B员工 |
3000 |
2014-01-16 |
店B员工 |
2000 |
2014-01-16 |
小张 |
Union 与 Union all 区别的更多相关文章
- Union和Union All到底有什么区别
以前一直不知道Union和Union All到底有什么区别,今天来好好的研究一下,网上查到的结果是下面这个样子,可是还是不是很理解,下面将自己亲自验证: Union:对两个结果集进行并集操作,不包括重 ...
- union和union all的区别
UNION 写一篇联合查询(把前后两个表的查询结果集合在前表中)首先有个为什么需要 相同记录数?? 记错了.应该是union两张表的查询字段数目要一致,字段类型要相似相同的数据类型,至少是相似,可转化 ...
- Oracle之Union与Union all的区别
如果我们需要将两个select语句的结果作为一个整体显示出来,我们就需要用到union或者union all关键字.union(或称为联合)的作用是将多个结果合并在一起显示出来. union和unio ...
- 转 SQL Union和SQL Union All两者用法区别效率以及与order by 和 group by配合问题
SQL Union和SQL Union All两者用法区别效率以及与order by 和 group by配合问题 SQL Union和SQL Union All用法 SQL UNION 操作符 UN ...
- union与union all的区别
首先说下union与join的区别 1.union是以行增加的方式,进行连接:join是以列增加的方式进行连接: 2.union连接查询的两个表的字段必须要一一对应,数目相等:join则没有要求,但是 ...
- Ms SQLServer中的Union和Union All的使用方法和区别
Ms SQLServer中的Union和Union All的使用方法和区别 SQL UNION 操作符 UNION 操作符用于合并两个或多个 SELECT 语句的结果集. 请注意,UNION 内部的 ...
- union与union all 的区别
Union与Union All的区别 如果我们需要将两个select语句的结果作为一个整体显示出来,我们就需要用到union或者union all关键字.union(或称为联合)的作用是将多个结果合并 ...
- SQL Server函数---Union与Union All的区别
SQL Server函数---Union与Union All的区别 如果我们需要将两个select语句的结果作为一个整体显示出来,我们就需要用到union或者union all关键字.union(或称 ...
- Oracle中Union与Union All的区别(适用多个数据库)
Oracle中Union与Union All的区别(适用多个数据库) 如果我们需要将两个select语句的结果作为一个整体显示出来,我们就需要用到union或者union all关键字.union(或 ...
随机推荐
- BZOJ 2120 色彩数 暴力
标题效果:给定一个序列,两种操作: 1.询[l,r]间隔多少个不同的号码 2.单点变化 n,m<=1W 树盖树?树董事长?因此不必! 暴力之前,这个问题2s,不想复杂!适当的水太! 离散化一下! ...
- Android基础之——startActivityForResult启动界面并返回数据,上传头像
在android应用的开发过程中,常常会出现启动一个界面后填写部分内容后带着数据返回启动前的界面,最典型的应用就是登录过程.在非常多应用程序的模块中,都有"我的"这个模块,在未登录 ...
- VS2013调试的时候出现 “检测到在集成的托管管道模式下不适用的 ASP.NET 设置的解决方法”
在web.config里面添加了下面一句,完美解决 <system.webServer> <validation validateIntegratedModeConfiguratio ...
- UiAutomator源码分析之UiAutomatorBridge框架
上一篇文章<UIAutomator源码分析之启动和运行>我们描述了uitautomator从命令行运行到加载测试用例运行测试的整个流程,过程中我们也描述了UiAutomatorBridge ...
- UC编程:输入输出重定向(标准IO)
[c] #include <stdio.h> #include <stdlib.h> int main() { FILE *fp; char szBuf[100]; /* 将屏 ...
- Spring IOC 之Bean定义的继承
一个Bean的定义可以包含大量的配置信息,包括构造器参数.属性值以及容器规范信息,比如初始化方法.静态工厂方法名字等等.一子bean的定义可以从父bean的定义中继承配置数据信息.子bean定义可以覆 ...
- Windows环境搭建Web自动化测试框架Watir
Windows环境搭建Web自动化测试框架Watir 一.前言 Web自动化测试一直是一个比较迫切的问题,对于现在web开发的敏捷开发,却没有相对应的敏捷测试,故开此主题,一边研究,一边将We ...
- CQRS架构如何实现高性能
CQRS架构如何实现高性能 CQRS架构简介 前不久,看到博客园一位园友写了一篇文章,其中的观点是,要想高性能,需要尽量:避开网络开销(IO),避开海量数据,避开资源争夺.对于这3点,我觉得很有道理. ...
- Mysql高级之权限检查原理
原文:Mysql高级之权限检查原理 用户进行数据库操作分为两步: 1 是否有权限连接,根据host,name,password: 2 是否有权限进行CURD: 图示解说: 关于用户权限在哪里进行存放? ...
- Amazon前技术副总裁解剖完美技术面试
Amazon前技术副总裁解剖完美技术面试 投递人 itwriter 发布于 2014-03-03 14:30 评论(0) 有1729人阅读 原文链接 [收藏] « » 英文原文:The Anat ...