欢迎来到代码驿站!

Oracle

当前位置:首页 > 数据库 > Oracle

Oracle In和exists not in和not exists的比较分析

时间:2021-01-25 10:27:19|栏目:Oracle|点击:
把这两个很普遍性的网友比较关心的问题总结回答一下。

in和exist的区别

从sql编程角度来说,in直观,exists不直观多一个select,
in可以用于各种子查询,而exists好像只用于关联子查询

从性能上来看
exists是用loop的方式,循环的次数影响大,外表要记录数少,内表就无所谓了

in用的是hash join,所以内表如果小,整个查询的范围都会很小,如果内表很大,外表如果也很大就很慢了,这时候exists才真正的会快过in的方式。

not in和not exists的区别

not in内外表都进行全表扫描,没有用到索引;
not extsts 的子查询能用到表上的索引。

所以推荐用not exists代替not in

不过如果是exists和in就要具体看情况了

有时间用具体的实例和执行计划来说明。

上一篇:centos7.7安装oracle11g脚本(推荐)

栏    目:Oracle

下一篇:oracle 12c创建可插拔数据库(PDB)与用户详解

本文标题:Oracle In和exists not in和not exists的比较分析

本文地址:http://www.codeinn.net/misctech/50776.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有