程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle數據庫基礎 >> 優化調整Oracle 8i數據庫系統

優化調整Oracle 8i數據庫系統

編輯:Oracle數據庫基礎

如何使用CostBased優化器優化查詢操作?

Oracle 提供了基於成本(CostBased)和基於規則(RuleBased)兩種優化器,簡稱為CBO和RBO,用於確定查詢操作的執行計劃。CostBased優化器將計算各種執行計劃的開銷,然後選出最低成本的執行計劃。可使用下列方法選擇使用CBO:

1.在INIT.ORA文件中設置參數OPTIMIZER_MODE=choose;

2.在Session級設置OPTIMIZER_GOAL=FIRST_ROWS或ALL_ROWS。

3、在查詢語句中使用Hint,包括CHOOSE、ALL_ROWS、FIRST_ROWS等。

為什麼我的執行計劃不是最好的?

CBO是依賴於表的一些統計信息來選擇出最低成本的執行計劃,當這些統計信息不准確時,產生的計劃便可能不是最佳的。因而應使用ANALYZE命令及時對表進行分析統計。

我的查詢上周的性能很好,為什麼現在查詢速度很慢?

這是由於執行計劃被改變而造成的,下列因素將會改變一個執行計劃:

1、INIT.ORA文件中的參數OPTIMIZER_MODE被改變;

2、表上定義或改變了並行查詢度;

3、使用ANALYZE命令重新分析了表,而且使用了ESTIMATE方式,這種方式選擇不同的百分比可產生不同的分析結果;

4、DB_FILE_MULTIBLOCK_READ_COUNT參數被修改;5、SORT_AREA_SIZE參數被修改。 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved