登录模块加载中...
会员投稿 投稿指南 今天是:
打印本页 | 关闭窗口 | 双击滚屏 您的位置首页>>网页制作学习园地>>数据库类>>ORACLE>>oracle集操作和exists、in的运用场景
oracle集操作和exists、in的运用场景
来源: ‖ 作者: ‖ 点击: ‖ 时间:12-10-16 15:59:31 ‖ 【 】‖ 我要投稿
oracle集操作和exists、in的运用场景

    1 集操作

    定义:把多个sql的结果集,通过逻辑上的整合运算,拼在一起显示。

    集操作缺省下都是按第一个查询的第一列升序排序,当然除了union all:

    minus:取差集,可用于对两个结果集进行测试

    union:取并集,除重

    union all:取并集,不剔重

    intersect:取交集

    注释:

    ① union all不排序、不剔重,在效率上比union高。在业务允许下,用union all,则不用union  www.2cto.com

    ② 两表作集操作时,字段类型、个数要相同,列的名字可以不必相同;若不一样可补齐,补齐时应注意字段类型,进行显示转换: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可以将子查询结果定位常量,不影响查询结果,而且,效率高。

    比如:

    [sql]

    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的结果集是一样的。

加入收藏:  加入收藏夹  | 发送给好友:  发送给好友
责任编辑:admin
相关文章列表
请文明参与讨论,禁止漫骂攻击。  
网友评论