Oracle 最佳化引數 optimizer_mode 介紹

season0891發表於2010-08-25

Oracle 在執行SQL語句時,有兩種最佳化方法:即基於規則的RBO和基於代價的CBO。 在SQL執教的時候,到底採用何種最佳化方法,就由Oracle引數 optimizer_mode 來決定。

SQL> show parameter optimizer_mode

NAME                                  TYPE         VALUE
------------------------------------ ----------- ------------------------------
optimizer_mode                        string       CHOOSE

optimizer_mode 引數值共有以下四個:

第一:CHOOSE

   這個是Oracle的預設值。採用這個值時,Oracle即可以採用基於規則RBO,也可以採用基於代價的CBO,到底使用那個值,取決於當前SQL的被訪問的表中是不是有可以使用的統計資訊。

     如果有多個被訪問的表,其中有一個或多個有統計資訊,那麼Oralce會對沒有統計資訊的表進行取樣統計(即不全部取樣),統計完成後,使用基於代價的最佳化方法CBO。

    如果所有被訪問的表都沒有統計資訊,Oracle就會採用基於規則的最佳化方法RBO。

第二:ALL_ROWS

不管是不是有統計資訊,全部採用基於成本的最佳化方法CBO。

第三:FIRST_ROWS_n

不管是不是有統計資訊,全部採用基於成本的最佳化方法CBO,並以最快的速度,返回前N行記錄。

第四:FIRST_ROWS

使用成本和試探法相結合的方法,查詢一種可以最快返回前面少數行的方法;這個引數主要用於向後相容。

第五:RULE

這個引數正好和ALL_ROWS相反,不管是不是統計資訊,全部採用基於規則的最佳化方法。

如何更改 optimizer_mode 的引數呢?可以用以下的方法。

SQL> alter session set optimizer_mode='RULE';

會話已更改。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/90618/viewspace-671837/,如需轉載,請註明出處,否則將追究法律責任。

相關文章