文章详情

  • 游戏榜单
  • 软件榜单
关闭导航
热搜榜
热门下载
热门标签
php爱好者> php文档>成本的单位

成本的单位

时间:2010-07-02  来源:TOMSYAN

以前一直没有搞懂成本的单位是什么,看了<<基于成本的ORACLE优化规则>> 总算搞明白了。 摘自书中的一段文字以供参考:

According to the CPU costing model:

Cost = (

#SRds * sreadtim +

#MRds * mreadtim +

#CPUCycles / cpuspeed

) / sreadtim

where

#SRDs - number of single block reads

#MRDs - number of multi block reads

#CPUCycles - number of CPU Cycles

sreadtim - single block read time

mreadtim - multi block read time

cpuspeed - CPU cycles per second

转译过来,上述代码的含义为:

成本指的是花费在单块读取上的时间,加上花费在多块读取上的时间,再加上所需的CPU处理的时间,然后将总和除以单块读取所花费的时间。也就是说,成本是语句的预计执行时间的总和,以单块读取时间单元的形式来表示。

为什么Oracle会为成本计算选择这样一种古怪的时间单位,而不是简单地以厘秒(1/100秒)为单位进行计算?这纯粹是为了满足向后兼容性。在Oracle 8i(包括9i,如果不启用CPU成本计算)中,成本仅仅是对I/O请求数目进行计算,这种计算方式在单数据块和多数据块I/O之间并没有区别。因此,为了向后兼容,从Oracle 8i升级到Oracle 9i时,如果新的代码以单块读取时间为单位来报告时间,那么典型的(轻量级的,基于索引的)OLTP查询的成本所产生的数字并不会改变太多。

相关阅读 更多 +
排行榜 更多 +
辰域智控app

辰域智控app

系统工具 下载
网医联盟app

网医联盟app

运动健身 下载
汇丰汇选App

汇丰汇选App

金融理财 下载