站点首页 | 外语考试 | 电脑认证 | 会计考试 | 职业资格 | 建筑工程 | 学历考试 | 外贸考试 | 医药考试 | 公务员考试
热门文章
搜索
您现在的位置: 考试吧 >> 电脑认证 >> Oracle认证 >> 综合辅导 >> 文章正文
什么时候oracle使用绑定变量性能反而更差

当我在做培训时,在解释绑定变量的好处时,大家都比较容易理解。但是,对于并不是任何时候绑定变量都是最优的。这一点很多人不是和理解。下面就讨论一下在什么时候会出现绑定变量会使性能变差。

扫描成本和OPTIMIZER_INDEX_COST_ADJ

我们知道,在CBO模式下,Oracle会计算各个访问路径的代价,采用最小代价的访问路径作为语句的执行计划。而对于索引的访问代价的计算,需要根据一个系统参数OPTIMIZER_INDEX_COST_ADJ来转换为与全表扫描代价等价的一个值。这是什么意思呢?我们先稍微解释一下这个参数:OPTIMIZER_INDEX_COST_ADJ。它的值是一个百分比,默认是100,取值范围是1~10000。当估算索引扫描代价时,会将索引的原始代价值乘以这个百分比,将换算后的值作为与全表扫描代价比较的值。也就是说,当这个值为100时,计算出的索引扫描代价就是它的原始代价:

COST_COM = COST_ORG * OPTIMIZER_INDEX_COST_ADJ/100

看以下例子:

SQL> create table T_PEEKING (a NUMBER, b char(1), c char(2000));
 
Table created.
 
SQL>
SQL> create index T_PEEKING_IDX1 on T_PEEKING(b);
 
Index created.
 
 
SQL> begin
  2    for i in 1..1000 loop
  3      insert into T_PEEKING values (i, 'A', i);
  4    end loop;
  5
  6    insert into T_PEEKING values (1001, 'B', 1001);

[1] [2] [3] [4] [5] [6] [7] [8] [9] [10]  ... 下一页  >> 

Copyright(c) kaos8.com All rights reserved. 浙ICP备06001730号