手机
当前位置:查字典教程网 >编程开发 >Oracle教程 >Oracle In和exists not in和not exists的比较分析
Oracle In和exists not in和not exists的比较分析
摘要:把这两个很普遍性的网友比较关心的问题总结回答一下。in和exist的区别从sql编程角度来说,in直观,exists不直观多一个select...

把这两个很普遍性的网友比较关心的问题总结回答一下。

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 minus使用

Oracle中基于hint的3种执行计划控制方法详细介绍

Oracle中sys和system的区别小结

OracleLogminer使用

基于oracle expdp命令的使用详解

Oracle中instr函数使用方法

Hibernate Oracle sequence的使用技巧

深入Oracle的left join中on和where的区别详解

Oracle监听器服务不能启动的7步解决法

精品推荐
分类导航