文章詳情頁
優化調整Oracle 8i數據庫系統
瀏覽:108日期:2023-11-21 09:26:35
如何使用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參數被修改。
排行榜