当前位置: 首页 > 图文教程 > 数据库 > Oracle > Oracle In和exists not in和not exists的比较分析

Oracle
浅谈Oracle数据库SCN号
浅谈DBMS_SCHEDULER如何使用
数据丢失 Oracle闪回
Oracle教程:完全备份的SH文件
Oracle服务器参数文件管理技巧
Oracle认证:向视图中插入数据的方法
Oracle教程:Oracle基础知识整理
使用Java和oracle实现BLOB字段的字符串读取
Oralce 9i安装OID目录服务器说明
Oracle 11gR2重要的4个新特性说明
OpenCalais:为Oracle数据库添加语义元数据为Oracle数据库添加语义元数据
phpBB 3.0.6 RC1简单介绍和下载
Oracle:oracle的体系结构,你了解多少?
怎样才能限制SQL Server只能让指定的机器连接
有关Oracle数据库的备份情况
ORACLE8的分区管理
常见数据库系统之比较 - Oracle数据库
在ORACLE中移动数据库文件
ORACLE常见错误代码的分析与解决(三)
Oracle中如何直接运行OS命令(上)

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-13   浏览: 488 ::
收藏到网摘: n/a

一个是问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就要具体看情况了
有时间用具体的实例和执行计划来说明。