加入收藏 | 设为首页 | 会员中心 | 我要投稿 常州站长网 (https://www.0519zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 教程 > 正文

Oracle In和exists not in和not exists的比较详解

发布时间:2021-11-26 21:15:09 所属栏目:教程 来源:互联网
导读:把这两个很普遍性的网友比较关心的问题总结回答一下。 in和exist的区别 从sql编程角度来说,in直观,exists不直观多一个select, in可以用于各种子查询,而exists好像只用于关联子查询 从性能上来看 exists是用loop的方式,循环的次数影响大,外表要记录数少

把这两个很普遍性的网友比较关心的问题总结回答一下。
 
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就要具体看情况了
 
有时间用具体的实例和执行计划来说明。

(编辑:常州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读