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

 

今天在csdn上看到两个问题,

 

一个是问in exist的区别,一个是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就要具体看情况了

 

 

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




 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

inthirties

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值