时 间 记 忆
<<  < 2011 - 12 >  >>
1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31

最 新 评 论

最 近 更 新

最 新 留 言

搜 索

用 户 登 录

博 客 相 册

我 的 圈 子

我 的 好 友

友 情 连 接



 
 
Oracle数据库中有关CBO优化的三个问题
[ 2007-12-23 15:50:00 | By: 青鸟 ]
 

.如何使用CostBased优化器优化查询操作?

Oracle 提供了基于成本(CostBased)和基于规则(RuleBased)两种优化器,简称为CBORBO,用于确定查询操作的执行计划。CostBased优化器将计算各种执行计划的开销,然后选出最低成本的执行计划。可使用下列方法选择使用CBO

1.INIT.ORA文件中设置参数OPTIMIZER_MODE=choose

2.Session级设置OPTIMIZER_GOAL=FIRST_ROWSALL_ROWS

3、在查询语句中使用Hint,包括CHOOSEALL_ROWSFIRST_ROWS等。

.为什么我的执行计划不是最好的?

CBO是依赖于表的一些统计信息来选择出最低成本的执行计划,当这些统计信息不准确时,产生的计划便可能不是最佳的。因而应使用ANALYZE命令及时对表进行分析统计。

.我的查询上周的性能很好,为什么现在查询速度很慢?

这是由于执行计划被改变而造成的,下列因素将会改变一个执行计划:

1INIT.ORA文件中的参数OPTIMIZER_MODE被改变;

2、表上定义或改变了并行查询度;

3、使用ANALYZE命令重新分析了表,而且使用了ESTIMATE方式,这种方式选择不同的百分比可产生不同的分析结果;

4DB_FILE_MULTIBLOCK_READ_COUNT参数被修改;5SORT_AREA_SIZE参数被修改。

 

 
 
  • 标签:语句 
  • 发表评论:
     
     
     
    天涯博客
    天涯博客欢迎您!