当前位置:  数据库>oracle

Oracle中的in和exists区别

    来源: 互联网  发布时间:2017-05-22

    本文导语: 在SQL查询语句中,经常会很多人对in和exists的查询效率进行疑惑,很多人都认为exists查询速度要比in快,其实这个说话不绝对,exists和in都有它们适合的场合,不然在SQL查询标准中,也不会一直不遗余力的进行支持。 先说in,通常...

在SQL查询语句中,经常会很多人对in和exists的查询效率进行疑惑,很多人都认为exists查询速度要比in快,其实这个说话不绝对,exists和in都有它们适合的场合,不然在SQL查询标准中,也不会一直不遗余力的进行支持。

先说in,通常情况下我们即认为是先将in子句里面的内容查询出来,然后对In的查询结果进行合并,再根据查询结果对主SQL进行一个个的查询,即相当于以下转换。
  select * from T1 where x in (select y from T2);  
  可以转换成如下  
  select * from T1,(select distinct y from T2) T2  
  where T1.x=T2.y;

再说exists,exists即先从主SQL中找到每一条合适的记录,然后将结果放到子SQL中与之匹配,即  
  select * from T1 where exists (select NULL from T2 where T2.y=T1.x);  
  可以转换成
  for cursor1 in (select * from T1)  
  loop  
  if (exists (select NULL from T2 where T2.y=cursor1.x))  
  then  
  返回记录;  
  end if;  
end loop;

 

这样子,即我们很容易会认为在子SQL数据量比较大的时候,exists效率会高于in,而只有在in的结果集非常小的时候,in的效率才能比exists好, 这样是否就正确了呢?通过对很多的SQL进行分析,会发现这个准则也不绝对,特别是10g,11g之后的数据库,in和exist很多时候效果都差不多,这又是为什么呢?

再深入分析,Oracle优化器规则中有三种分析规则,以前主要是基于规则的优化器,即通过预先定义一系列的优先级顺序,比如唯一索引优先于普通索引,又或者是等于索引优先于大于索引,这样即按规则的优先顺序去执行SQL,所以我们就有了在子句结果集很小的时候,in查询速度会快于exists,反之则exists速度会更快的结论,在oracle 9i中,默认提供是基于选择的优化器,即当有分析数据时,采用基于成本的优化方式,没有则仍采用基于规则的查询方式,这样优化模式下基本等同于基于规则或者基于成本。在10g之后的版本,默认都是以基于成本的方式进行,这时候,oracle会先找出可能的执行方式,然后计算出每个执行计划的成本,再选择以较低成本的方式进行计算,这样子在对in和exists的分析中,这两种写法会相互转换,那个统计的成本信息低则会选择那种方式。当然由于oracle的成本信息并不是全量统计得出来的结果,也会有一定的误差,再统计信息是需要人工(或定时)去执行统计的,如果操作大量数据后,没有进行统计,偏差也会很大。

这样子的分析是否准确了呢?in和exists又是不是只有这两种查询方式呢?在基于成本的优化方式中,又如何对in和exists进行优化?SQL的优化又是否与具体数据有关?

阅读延伸:关于Oracle中in和exists的区别:


    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • Oracle 数据库(oracle Database)性能调优技术详解
  • Linux /$ORACLE_HOME $ORACLE_HOME
  • ORACLE日期相关操作
  • Linux系统下Oracle的启动与Oracle监听的启动
  • ORACLE数据库常用字段数据类型介绍
  • 请问在solaris下安装ORACLE,用root用户和用oracle用户安装有什么区别么?
  • Oracle 12c的九大最新技术特性介绍
  • 网间Oracle的连接,远程连接Oracle服务器??


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,