服务热线:13616026886

技术文档 欢迎使用技术文档,我们为你提供从新手到专业开发者的所有资源,你也可以通过它日益精进

位置:首页 > 技术文档 > 数据库技术 > Oracle技术 > Oracle开发 > 查看文档

详细讲解有关"cbo"优化的三个疑难问题

一、如何使用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参数被修改。

扫描关注微信公众号