SQL 中的 UNION 和UNION ALL 有什么区别?

 我来答
729089549
2011-05-10 · TA获得超过421个赞
知道小有建树答主
回答量:77
采纳率:0%
帮助的人:66.2万
展开全部
UNION表示“并”,当用的时候,系统会自动将重复的元组去掉,如果要保留重复元组则就用UNION ALL。
楼主,采纳吧!
盈盈笑语o0
2018-04-13 · TA获得超过6374个赞
知道小有建树答主
回答量:30
采纳率:0%
帮助的人:3822
展开全部

union 将两个表连接后删除其重复的项。


union all 将两个表连接都不删除其重复的项。

补充资料:


数据库中,UNION和UNION ALL都是将两个结果集合并为一个,但这两者从使用和效率上来说都有所不同。


UNION在进行表链接后会筛选掉重复的记录,所以在表链接后会对所产生的结果集进行排序运算,删除重复的记录再返回结果。实际大部分应用中是不会产生重复的记录,最常见的是过程表与历史表UNION。如:


select * from users1 union select * from user2

这个SQL在运行时先取出两个表的结果,再用排序空间进行排序删除重复的记录,最后返回结果集,如果表数据量大的话可能会导致用磁盘进行排序。


而UNION ALL只是简单的将两个结果合并后就返回。这样,如果返回的两个结果集中有重复的数据,那么返回的结果集就会包含重复的数据了。

从效率上说,UNION ALL 要比UNION快很多,所以,如果可以确认合并的两个结果集中不包含重复的数据的话,那么就使用UNION ALL,如下:


select * from user1 union all select * from user2

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
wangzhiqing999
2011-05-11 · TA获得超过1.6万个赞
知道大有可为答主
回答量:7048
采纳率:100%
帮助的人:3293万
展开全部
UNION 会合并重复数据,(由于要合并重复,该操所 隐藏着一个 排序的操作。)
UNION ALL 简单合并,不会合并重复的。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
weizi8882011
2011-05-18
知道答主
回答量:1
采纳率:0%
帮助的人:0
展开全部
如果我们需要将两个select语句的结果作为一个整体显示出来,我们就需要用到union或者union all关键字。union(或称为联合)的作用是将多个结果合并在一起显示出来。
union和union all的区别是,union会自动压缩多个结果集合中的重复结果,而union all则将所有的结果全部显示出来,不管是不是重复。
Union:对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序;
Union All:对两个结果集进行并集操作,包括重复行,不进行排序;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
liver1123
2011-05-10 · TA获得超过4636个赞
知道大有可为答主
回答量:2484
采纳率:100%
帮助的人:1755万
展开全部
UNION: 指定合并多个结果集并将其作为单个结果集返回。
ALL: 将全部行并入结果中。其中包括重复行。如果未指定该参数,则删除重复行。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(5)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式