写点什么

ORACLE 进阶(十二)union(all) 学习总结

  • 2022 年 7 月 10 日
  • 本文字数:1271 字

    阅读完需:约 4 分钟

ORACLE进阶(十二)union(all)学习总结

一、前言

在工作中,查看到类似于如下的 SQL 语句:


select sum(count)   from (select count(1) count           from tb          left outer join WFWKSEQTAB             on tb.JUGSUMID = tb1.SEQNO          inner join cdeorg             on tb.ibkcde = cdeorg.ibkcde          where 1 = 1            AND (FNAUTM IS NULL or fnautm = 0)            AND (tb.FLWSTS != '3' or tb.FLWSTS IS NULL)            and UPPER(tb.customername) like '%' || 'shq_test_20180302' || '%'          ESCAPE '/'            and tb.biztyp in ('1', '2', '5', '02')            and tb.jugsumid in                (select jugsumid from casaprlogtab where (1 = 1))         union         select count(1) count           from tb...
复制代码


  • Union:对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序;

  • Union All:对两个结果集进行并集操作,包括重复行,不进行排序;


1.Union 指令的目的是将两个 SQL 语句的结果合并起来,可以查看你需要查询结果例如:


SELECT Date FROM Store_Information  UNION     SELECT Date FROM Internet_Sales;
复制代码

二、应用注意事项

union用法中,两个SELECT 语句的字段类型匹配,并且字段的类型要相同。


如上面的例子,在实际的软件开发过程,会遇到更复杂的情况,具体请看下面的额子


select '1' as type,FL_ID ,FL_CODE,FL_CNAME,_FLDA,FL_PARENTID from FLDA   WHERE ZT_ID = 2006030002    union      SELECT '2' as Tpye,XM_ID,_XM_CODE,XM_CNAME,FL_ID FROM XMDA         WHERE exists (SELECT * FROM (SELECT FL_ID FROM FLDA WHERE ZT_ID=200603002 ) a where XMDA.fl_id=fl_id)          order by type,FL_PARENTID , FL_ID;
复制代码


这句话的意思是将两个 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子句改变排序方式。

发布于: 刚刚阅读数: 4
用户头像

No Silver Bullet 2021.07.09 加入

岂曰无衣 与子同袍

评论

发布
暂无评论
ORACLE进阶(十二)union(all)学习总结_oracle_No Silver Bullet_InfoQ写作社区