ORACLE进阶(十二)union(all)学习总结_oracle的union all底层算法

     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`需要进行排序,去除重复记录,效率低。


### 三、小结



### 最后

在面试前我花了三个月时间刷了很多大厂面试题,最近做了一个整理并分类,主要内容包括html,css,JavaScript,ES6,计算机网络,浏览器,工程化,模块化,Node.js,框架,数据结构,性能优化,项目等等。



包含了腾讯、字节跳动、小米、阿里、滴滴、美团、58、拼多多、360、新浪、搜狐等一线互联网公司面试被问到的题目,涵盖了初中级前端技术点。

*   HTML5新特性,语义化

*   浏览器的标准模式和怪异模式

*   xhtml和html的区别

*   使用data-的好处

*   meta标签

*   canvas

*   HTML废弃的标签

*   IE6 bug,和一些定位写法

*   css js放置位置和原因

*   什么是渐进式渲染

*   html模板语言

*   meta viewport原理

![](https://img-blog.csdnimg.cn/img_convert/64590c67cb47cd552a892ba710477f64.png)



![](https://img-blog.csdnimg.cn/img_convert/17fdfcb90fad04acc5e7273d1f853880.png)

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值