• 转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.

  • 相关阅读:
    JAVA常见面试题之Forward和Redirect的区别
    springMVC学习笔记(二)-----注解和非注解入门小程序
    springMVC学习笔记(一)-----springMVC原理
    C语言关键字
    JAVA HASHMAP 如何用
    java中HashMap详解
    java中dao层和service层的区别是什么?
    到底DAO是什么?为什么要有它的存在?
    Ubuntu命令基础
    使用VMWare12.0安装Ubuntu系统
  • 原文地址:https://www.cnblogs.com/tracy/p/1940229.html
Copyright © 2020-2023  润新知