OracleIn和existsnotin和notexists的比较分析

春天来了,花园里开满了花,有梅花,有迎春花,有山茶花,有丁香花,真是太好看了。
把这两个很普遍性的网友比较关心的问题总结回答一下。 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就要具体看情况了 有时间用具体的实例和执行计划来说明。

到此这篇关于OracleIn和existsnotin和notexists的比较分析就介绍到这了。世间最温暖的字莫过于爱,最伟大的力量莫过于爱。更多相关OracleIn和existsnotin和notexists的比较分析内容请查看相关栏目,小编编辑不易,再次感谢大家的支持!

您可能有感兴趣的文章
OracleIndex索引无效的原因与如何解决方法

OracleIndex的三个问题