oracle 集操作和exists、in的运用场景

  1 集操作

             定义:把多个sql的结果集,通过逻辑上的整合运算,拼在一起显示。
              集操作缺省下都是按第一个查询的第一列升序排序,当然除了union all:
              minus:取差集,可用于对两个结果集进行测试
              union:取并集,除重
              union all:取并集,不剔重
              intersect:取交集


             注释
              ① union all不排序、不剔重,在效率上比union高。在业务允许下,用union all,则不用union
              ② 两表作集操作时,字段类型、个数要相同,列的名字可以不必相同;若不一样可补齐,补齐时应注意字段类型,进行显示转换:to_char、to_number、to_date等
              ③ 多个集操作可通过括号改变sql引擎的执行顺序(缺省sql引擎是自顶向下)
              ④ union、minus和intersect的共同点:
                 剔重、排序、不忽略null
              ⑤ order by只能出现在语句的最后,是对整个集操作结果的排序,列名、别名或者按位置指定,但不能使用第一个select没有出现的列
              ⑥ 第一个select语句接收列名、别名,或位置记号,查询结果的列名和第一个select语句保持一致
              ⑦ 可以用于子查询

   2 exists、in的运用场景

            能不写子查询,尽量不写子查询,而是直接编写多表连接操作。理由如下:
             ① oracle CBO在parse阶段,会尽可能把子查询转化为多表连接
             ② 子查询可读性较低
             ③ 复杂的逻辑,子查询可能导致oracle CBO选择错误的执行路径
             但如果必须写子查询,到底是in还是exists?exists/not exists专门用于关联子查询。10g之后,oracle对in的改进,这两者无甚区别。


            in和select的技术原理
             ㈠ in:先进行子查询,再进行主查询
             ㈡ exists:先进行主查询,再到子查询中过滤


           in和exists的使用建议
             Ⅰ 如果限制性强的条件在子查询,则使用in
             Ⅱ 如果限制性强的条件在主查询,则使用exists
             可用查询结果集来理解上面这段话,采用最优化匹配原则:拿最小记录匹配大记录。限制性强,则结果集小;反之,则大。
             注释:
             ① 使用exists可以将子查询结果定位常量,不影响查询结果,而且,效率高。
                比如:

select e.*
  from emp e
 where exists 
 (select 1 from dept d
   where e.deptno=d.deptno and
         d.dname='SALES')


            ② not in可能会因为null而改变其行为导致和not exists结果集有出入。然而,在相关子查询下,not in和not exists的结果集是一样的。

 

 

关于IN和EXISTS,IN是把内表和外表做HASH连接,则EXISTS是对外表做LOOP循环,每次LOOP循环再对内表进行查询。
 如果内表和外表大小相当,则使用IN和EXISTS效率差不多少。

 如果子查询的表大,则使用EXISTS,如果子查询表小,则使用IN效率高。

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值