ORACLE 进阶(十二)union(all) 学习总结
一、前言
在工作中,查看到类似于如下的 SQL 语句:
Union
:对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序;Union All
:对两个结果集进行并集操作,包括重复行,不进行排序;
1.Union
指令的目的是将两个 SQL 语句的结果合并起来,可以查看你需要查询结果例如:
二、应用注意事项
union
用法中,两个SELECT
语句的字段类型匹配,并且字段的类型要相同。
如上面的例子,在实际的软件开发过程,会遇到更复杂的情况,具体请看下面的额子
这句话的意思是将两个 SQL 语句UNION
查询出来,查询的条件就是看 XMDA 表中额 FL_ID 是否和主表 FLDA 里的 FL_ID 值匹配(也就是存在)。
UNION
在进行表连接后会筛选掉重复的额记录,所以表连接后会对所产生的结果集进行排序运算,删除重复的记录再返回结果。
在查询中会遇到UNION ALL
,他的用法和UNION
一样,只不过UNION
包含distinct
功能,它会把两张表重复了的记录去掉,而union all
不会, 所以从效率上讲,union all
会高一点,但实际中用得到的并不是很多。
表头会用到第一个连接块的字段,而UNION all
只是简单的将两个结果合并后就返回,这样,如果返回到额两个结果集中有重复的额数据,那么返回到结果集就包含重复数据了。
从效率上来说,UNION ALL
要比 UNION
快的多,所以,如果可以确认合并的两个结果集不包含重复的数据的话,那么就使用UNION ALL
。
尽量使用UNION ALL
,因为UNION
需要进行排序,去除重复记录,效率低。
三、小结
Union
可以对字段名不同但数据类型相同的结果集进行合并;如果字段名不同的结果集进行
Union
,那么对此字段的Order by
子句将失效;
Union
,对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序;
Union All
,对两个结果集进行并集操作,包括重复行,不进行排序;可以在最后一个结果集中指定
Order by
子句改变排序方式。
版权声明: 本文为 InfoQ 作者【No Silver Bullet】的原创文章。
原文链接:【http://xie.infoq.cn/article/f27dd353634982cf7bcc5ba12】。文章转载请联系作者。
评论