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(或 ...
随机推荐
- Linux经常使用命令(一) - ls
ls命令是linux下最经常使用的命令.ls命令就是list的缩写, 缺省下ls用来打印出当前文件夹的清单, 假设ls指定其它文件夹, 那么就会显示指定文件夹里的文件及文件夹清单. 通过ls 命令不仅 ...
- 开源 java CMS - FreeCMS2.2 模型管理
项目地址:http://www.freeteam.cn/ 模型管理 从FreeCMS 2.0開始支持 通过模型添加删除字段,调整后台功能;支持网站.栏目.信息等模型. 因为操作方法同样.本文档以网站模 ...
- 使用Canvas基于手势可以使树秋千
用Canvas制作能够依据手势摆动的树 依据工作的须要.制作一个摆动的树做为页面的背景.为了添加页面的交互性,我又为背景中的树添加了鼠标(触控)事件,使他可以依据鼠标(触控)做出对应的动作,当手指做上 ...
- 关于SQL Server 2005 的自动远程数据库备份
原文:(原创)关于SQL Server 2005 的自动远程数据库备份 由于项目需要,需要对目标服务器上的数据库每天进行备份并转移,查阅网上的一些帮助,结合自己的实际需要,写了这篇文章,希望对有同样需 ...
- SharePoint 2010 加入项目到用户/欢迎菜单
SharePoint 2010 加入项目到用户/欢迎菜单 近期QQ群里有人问怎样加入链接项目到SharePoint 2010 网站右上角的下拉菜单中.事实上,SharePoint 20 ...
- 学习PHP时的一些总结(四)
目录的基本操作: 在系统的每个目录下都有两个特殊的目录"."和".." , 分别指示当前目录和当前目录的父目录. dirname() 返回目录的名称 path ...
- 添加MySql Metat Database 信息
有时候我们想看看 一个数据库上面 某种元素(比如表名)的所有信息,在Mysql上 我们可以通过引入information_schema 的方式,就可以非常方便的查看到. 添加步骤 Edit->P ...
- css3学习文档
什么是CSS3? CSS3是CSS2的升级版本,3只是版本号,它在CSS2.1的基础上增加了很多强大的新功能. 目前主流浏览器chrome.safari.firefox.opera.甚至360都已经支 ...
- C#将XML转换成JSON转换XML
原文:C#将XML转换成JSON转换XML using System; using System.Collections.Generic; using System.Linq; using Syste ...
- OpenGl绘制螺旋线
/** * 缓冲区工具类 */public class BufferUtil { /** * 将浮点数组转换成字节缓冲区 */ public static ByteBuffer arr2ByteB ...