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

举报
SHQ5785 发表于 2020/12/29 23:03:55 2020/12/29
【摘要】       在工作中,查看到类似于如下的SQL语句: select sum(count) from (select count(1) count from tb left outer join WFWKSEQTAB on tb.JUGSUMID = tb1.SEQNO inner join cdeorg on...

      在工作中,查看到类似于如下的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...

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • Union:对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序;
  • Union All:对两个结果集进行并集操作,包括重复行,不进行排序;

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

SELECT Date FROM Store_Information
UNION 
SELECT Date FROM Internet_Sales;

  
 
  • 1
  • 2
  • 3

注意

  • 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;

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

      这句话的意思是将两个SQL语句UNION 查询出来,查询的条件就是看XMDA表中额FL_ID是否和主表FLDA里的FL_ID值匹配(也就是存在)。

      UNION在进行表连接后会筛选掉重复的额记录,所以表连接后会对所产生的结果集进行排序运算,删除重复的记录再返回结果。

      2.在查询中会遇到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子句改变排序方式。

文章来源: shq5785.blog.csdn.net,作者:No Silver Bullet,版权归原作者所有,如需转载,请联系作者。

原文链接:shq5785.blog.csdn.net/article/details/79436561

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。