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(或 ...
随机推荐
- IOS中 init和initialize
一.init和initialize 1.方法类型 1> init属于对象方法,-开头 2> initialize属于类方法,+开头 2.调用时刻 1> init:每个对象初始化的时候 ...
- 使用IntelliLock加密授权你的.Net程序
原文:使用IntelliLock加密授权你的.Net程序 转自:http://www.nsoff.com/post/2012/05/23/%E4%BD%BF%E7%94%A8IntelliLock%E ...
- Post和Get差异
GET和POST差别例如以下: 1,生成方式 get方式有四种:1)直接在URL地址栏中输入URL.2)网页中的超链接.3)form中method为get. 4)form中method为空时.默认是g ...
- unity3d插件Daikon Forge GUI 中文教程-1-Daikon Forge介绍
(游戏蛮牛首发)大家好我是孙广东官网提供了专业的视频教程http://www.daikonforge.com/dfgui/tutorials/,只是是在youtube上,要观看是须要FQ的. 只是教程 ...
- Redis 中文入库成功,读取数据写入文件乱码问题
近期须要用到redis ,可是在编码这个问题上,纠结了非常久. 需求 :每天一个进程将中文文件入库到redis中(不定时更新) ,另外几个进程读取redis中的信息 ,并处理数据结果.使 ...
- MonkenRunner通过HierarchyViewer定位控件的方法和建议(Appium/UIAutomator/Robotium姊妹篇)
1. 背景 在使用MonkeyRunner的时候我们经常会用到Chimchat下面的HierarchyViewer模块来获取目标控件的一些信息来辅助我们测试,但在MonkeyRunner的官网上是没有 ...
- 使用Row_Number()分页优化
记一次SQLServer的分页优化兼谈谈使用Row_Number()分页存在的问题 最近有项目反应,在服务器CPU使用较高的时候,我们的事件查询页面非常的慢,查询几条记录竟然要4分钟甚至更长,而且 ...
- hdu - 4979 - A simple math problem.(可反复覆盖DLX + 打表)
题意:一种彩票共同拥有 N 个号码,每注包括 M 个号码,假设开出来的 M 个号码中与自己买的注有 R 个以上的同样号码,则中二等奖,问要保证中二等奖至少要买多少注(1<=R<=M< ...
- List<string>和string[]
List<string>和string[] List<string>是集合:string[]是数组: ///////////////////////////////////// ...
- Knockout简单用法
Knockout简单用法 在最近做的一个项目中,页面数据全部通过js ajax调用webapi接口获取,也就是说页面的数据全部使用javascript脚本填充,这就想到了使用一个MVVM模式的js框架 ...