[性能调优]临时表上的索引没有被使用

    技术2024-11-19  6

        今天出了个这样的问题,在开发环境临时表上的索引正常,在生产环境的执行计划中没有

    被使用到。经分析,数据库做成时临时表为空,每次业务开始时插入大量数据,业务结束时

    将数据删除。因为统计情报不准确,导致生产环境上没有使用索引。

     

    加入HINT后,问题解决。

     

    总结:

    Oracle 10g开始,已经不在支持RBO模式,由CBO根据统计情报安排执行计划,所以需要

    经常收集数据库的统计情报。而业务上经常要用到临时表,由于其数据的特殊性

    (结束结束时删除),运行时的统计情报不准确,导致CBO在选择执行计划时出现错误。

    所以,建议在使用临时表且使用索引时,明确HINT使用哪个索引。

     

     

    最新回复(0)