分类: 数据库开发技术
2011-09-29 17:15:50
今天出了个这样的问题,在开发环境临时表上的索引正常,在生产环境的执行计划中没有
被使用到。经分析,数据库做成时临时表为空,每次业务开始时插入大量数据,业务结束时
将数据删除。因为统计情报不准确,导致生产环境上没有使用索引。
加入HINT后,问题解决。
总结:
Oracle 10g开始,已经不在支持RBO模式,由CBO根据统计情报安排执行计划,所以需要
经常收集数据库的统计情报。而业务上经常要用到临时表,由于其数据的特殊性
(结束结束时删除),运行时的统计情报不准确,导致CBO在选择执行计划时出现错误。
所以,建议在使用临时表且使用索引时,明确HINT使用哪个索引