您好,登錄后才能下訂單哦!
本篇內容介紹了“oracle優化器參數的值可以分為幾種”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
優化器參數optimizer_mode的值可以分為以下幾種,RULE,CHOOSE,FIRST_ROWS_n(n=1,10,100,1000),first_rows,all_rows
1,rule
SQL> show parameter optimizer_mode
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
optimizer_mode string RULE
表示oracle將使用RBO來解析目標SQL,此時目標SQL中涉及的各個對象的統計信息對于RBO來說,沒有任何作用。
2.choose
SQL> show parameter optimizer_mode
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
optimizer_mode string CHOOSE
取決于目標SQL中是否有統計值,如果沒有就不會使用RBO,如果有就會使用CBO。
3,first_rows_n(n=1,10,100,1000)
SQL> show parameter optimizer_mode
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
optimizer_mode string FIRST_ROWS_10
當first_rows_n中有任意一個值時,oracle會使用CBO來解析目標SQL,此時CBO在計算該SQL的各條執行路徑的成本值時的側重點在以最快的響應速度返回n(n=1,10,100,1000)條記錄,當滿足first_rows_n(n=1,10,100,1000)時,oracle會把所有對應的執行步驟的成本值改成一個很小的值(小于默認情況下CBO對同樣執行步驟的所計算的成本值)這樣oracle就沒有違背CBO選取執行計劃的原則(成本值最小)。
4,first_rows
SQL> show parameter optimizer_mode
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
optimizer_mode string FIRST_ROWS
表示oracle在解析SQL時會聯合使用CBO和RBO,這里大多數情況下還是會使用CBO。
5,all_rows
SQL> show parameter optimizer_mode
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
optimizer_mode string ALL_ROWS
oracle 10g后續版本的默認值,CBO在計算SQL的各條執行路徑的成本值時,側重最佳吞吐量(最少I/O和CPU資源的消耗量)
“oracle優化器參數的值可以分為幾種”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。