zoukankan      html  css  js  c++  java
  • 转AskTom:Oracle中关于in跟Exist谁效率高的问题。

    You Asked
    Tom:
    can you give me some example at which situation
    IN is better than exist, and vice versa. 
    and we said...
    Well, the two are processed very very differently.
    Select * from T1 where x in ( select y from T2 )
    is typically processed as:
    select * 
      from t1, ( select distinct y from t2 ) t2
    where t1.x = t2.y;
    The subquery is evaluated, distinct'ed, indexed (or hashed or sorted) and then joined to 
    the original table -- typically.
    As opposed to 
    select * from t1 where exists ( select null from t2 where y = x )
    That is processed more like:
      for x in ( select * from t1 )
      loop
      if ( exists ( select null from t2 where y = x.x )
      then 
      OUTPUT THE RECORD
      end if
      end loop
    It always results in a full scan of T1 whereas the first query can make use of an index 
    on T1(x).
    So, when is where exists appropriate and in appropriate?
    Lets say the result of the subquery
      ( select y from T2 )
    is "huge" and takes a long time. But the table T1 is relatively small and executing ( 
    select null from t2 where y = x.x ) is very very fast (nice index on t2(y)). Then the 
    exists will be faster as the time to full scan T1 and do the index probe into T2 could be 
    less then the time to simply full scan T2 to build the subquery we need to distinct on.
    Lets say the result of the subquery is small -- then IN is typicaly more appropriate.
    If both the subquery and the outer table are huge -- either might work as well as the 
    other -- depends on the indexes and other factors.

  • 相关阅读:
    安装RVM时报错 curl: (7) Failed to connect to raw.githubusercontent.com port 443: Connection refused
    如何查看docker run启动参数命令
    ProxySQL 基础篇
    Kafka too many open files解决
    离线方式搭建本地的nginx yum源
    Ceph配置参数详解
    osd自杀问题跟踪
    由一次slow-request浅谈Ceph scrub原理
    Power Apps 定制提交表单后的效果
    基于arm的Linux内核编译
  • 原文地址:https://www.cnblogs.com/tracy/p/1940229.html
Copyright © 2011-2022 走看看