如何使用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參數被修改。