oracle 集操作和exists、in的运用场景
来源:互联网 发布:拆分资金盘 源码 编辑:程序博客网 时间:2024/06/05 14:54
定义:把多个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.deptnoand
- d.dname='SALES')
② not in可能会因为null而改变其行为导致和not exists结果集有出入。然而,在相关子查询下,not in和not exists的结果集是一样的。
原文地址:http://blog.csdn.net/linwaterbin/article/details/7984261
- oracle 集操作和exists、in的运用场景
- oracle 集操作和exists、in的运用场景
- oracle 集操作和exists、in的运用场景
- oracle exists和in
- exists in 对比运用 (Oracle)
- oracle中的exists 和not exists、in的 用法详解
- Oracle exists 和 in 的真正区别
- oracle中in和exists的区别
- Oracle exists 和 in 的真正区别
- oracle中exists和in的问题
- oracle中exists和in的比较
- oracle中的exists和in的区别
- Oracle in和exists的区别
- Oracle中in和exists的选择
- oracle中in和exists的区别
- Oracle中in和exists的区别
- oracle中in和exists的区别
- Oracle中in和exists的选择
- ebs克隆新环境form端口占用问题解决
- 使用jq和flip插件来做了一个幻灯片翻转效果小demo
- Gmap.net开发资料搜集
- stretchableImageWithLeftCapWidth的使用
- PhraseQuery slop
- oracle 集操作和exists、in的运用场景
- SVN Windows下SVN服务器的搭建
- 【译】MySQL如何从完全备份恢复单个InnoDB表
- cvpr常用资源整理
- Jetty中文乱码问题的解决
- 我使用过的Linux命令之dmidecode - 查看硬件信息
- ajax中文乱码解决方法
- python头的编码形式
- Java开发中JDBC连接数据库代码和步骤.