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

来源:爱站网时间:2019-09-02编辑:网友分享
人们一直认为exists比in更快,但实际上它是不准确的,本文是爱站技术频道小编为大家具体分析的:Oracle In和exists not in和not exists的比较分析,一起跟着小编的步伐来学习吧!

人们一直认为exists比in更快,但实际上它是不准确的,本文是爱站技术频道小编为大家具体分析的:Oracle In和exists not in和not exists的比较分析,一起跟着小编的步伐来学习吧!

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就要具体看情况了

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

以上就是Oracle In和exists not in和not exists的比较分析,如果你想从事这个行业,建议你可以来爱站技术频道详加了解,谨慎为之。

上一篇:实现ORACLE字段自增的方法

下一篇:Oracle 用户权限管理方法

您可能感兴趣的文章

相关阅读

热门软件源码

最新软件源码下载