Oracle效能最佳化學習筆記之WHERE子句中的串連順序,oracle效能最佳化

來源:互聯網
上載者:User

Oracle效能最佳化學習筆記之WHERE子句中的串連順序,oracle效能最佳化

        ORACLE採用自下而上的順序解析WHERE子句,根據這個原理,表之間的串連必須寫在其他WHERE條件之前, 那些可以過濾掉最大數量記錄的條件必須寫在WHERE子句的末尾.

        例如:
       (低效,執行時間156.3秒)

SELECT … FROM EMP EWHERE  SAL > 50000AND    JOB = ‘MANAGER’AND    25 < (SELECT COUNT(*) FROM EMP             WHERE MGR=E.EMPNO);
        (高效,執行時間10.6秒)
SELECT … FROM EMP EWHERE 25 < (SELECT COUNT(*) FROM EMP             WHERE MGR=E.EMPNO)AND    SAL > 50000AND    JOB = ‘MANAGER’;
小註:
       本文摘自百度文庫,具體連結木有找到,抱歉。



oracle中where條件中的順序影響效率

不會影響的。
推薦答案是錯誤的,不知道什麼年代的事情了!
CBO最佳化器機基於代價的。
oracle會自動判斷,選擇率高的表作為驅動表來進行串連!
 
Oracle中where子句的執行順序?

從右向左執行的
 

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.