新客网
首页 | 新闻 | 系统·网络·服务器·安全 | 工具·办公 | 编程·数据库 | 图象·网页·运营 | 硬件·存储 | 专题教程 | 旧版
 → 当前位置:首页 > 教程 > 数据库 > Oracle > 正文

Oracle如何精确计算row的大小

XKER.COM   2006-5-19 10:31:12  来源:it168  点击:

第一步:计算整个Block Header的大小
   
    数据块头部所需要的空间大小由以下公式计算:
   
    Space after headers (hsize) = DB_BLOCK_SIZE - KCBH - UB4 - KTBBH - ((INITRANS - 1) * KTBIT) - KDBH
   
    其中的一些参数说明如下: 
   
    DB_BLOCK_SIZE:数据库的block大小,可以查询V$PARAMETER视图中获得。 
   
    KCBH、UB4、KTBBH、KTBIT、KDBH都是常量,这些定义的大小可以从V$TYPE_SIZE视图中获得。
   
    INITRANS是分配给表的初始化事务的数量,可以从USER_TABLES表中的INI_TRANS字段中获得。
   
    第二步:计算每个数据块可用的数据空间
    
    每个数据块为数据保留的空间是由PCTFREE参数所指定的,因此计算公式如下:
   
    Available data space (availspace) = CEIL(hsize * (1 - PCTFREE/100))
   
    – KDBT
   
    其中的一些参数说明如下:
   
    CEIL是取大于或者等于N的最小整数。
   
    PCTFREE是在表中预留出来用于UPDATE操作的空间,可以从USER_TABLES表中的PCT_FREE字段中获得。
   
    KDBT是常量,定义的大小可以从V$TYPE_SIZE视图中获得。如果你找不到KDBT的定义大小,用UB4定义的大小代替也可以。
   
    第三步:计算每行所用的空间大小
    
    计算每行所使用的空间大小是需要多步计算完成的。
   
    首先计算列的大小,包括字节的长度:
   
    Column size including byte length = column size + (1, if column size < 250, else 3)
   
    对于列的大小,既可以利用经验来判断其大小,也可以使用语句来计算每列的大小:
   
    Select avg(vsize(colname)) from table_name;
   
    接着,计算行的大小:
   
    Rowsize = row header (3 * UB1) + sum of column sizes including length bytes
   
    最后,计算每行所用的空间大小:
   
    Space used per row (rowspace) = MAX(UB1 * 3 + UB4 + SB2, rowsize) + SB2
   
    UB1、UB4、SB2都是常量,定义的大小可以从V$TYPE_SIZE视图中获得。
   
    当每行所占用的空间超过了一个数据块可用的空间的大小,但是仍然小于每个数据块保留给UPDATE操作的空间大小(例如,PCTFREE=0),每行记录将仍然被存储在它们自己的block块中。
   
    当每行的空间大小超过了每个数据块可用的空间,并且没有任何保留给UPDATE操作的空间可用了,此时,这行记录将被链接到另外一个block或者更多,因此,这个时候的存储的负载会比较高。
   
    第四步:计算在一个block中可以容纳最多的记录数量 
    
    可以使用下面的公式来计算一个数据block中可以容纳的记录的数量:

本新闻共2页,当前在第1页  1  2  

上一篇教程:ORACLE碎片整理(2)
下一篇教程:oracle监控数据库性能的SQL汇总
收藏本文】 【我要投稿】 【打印本文】 【论坛讨论】 【关闭窗口

相关文章
·比较SQL Server2005和Oracle 10g R2·获取本机上配置好的Oracle服务名
·DB2数据库与Oracle数据库之间远程复制·Oracle数据库的ORA-00257故障解决过程
·Oracle数据的异地自动备份·Oracle SQL性能优化系列讲座
·oracle教程 Oracle实例恢复详细分析总汇·windows优化系统后oracle9i本地连接失败
·Oracle logminer使用方法总结·oracle监控数据库性能的SQL汇总
·ORACLE碎片整理(2)·ORACLE碎片整理(1)

学院文章搜索
  
推荐文章
·编程过把瘾:自己动手写操
·数据恢复指南 专题
·硬盘“逻辑锁”解决办法
·DOS使用中的常见问题解答
·DOS下常用的相关网络命令
·Win2000优化技巧篇之:硬件
·惊心8小时:破译Windows运行
·菜鸟必备:超实用低级格式
·硬件有价数据无价 硬盘开盘
·国内数据恢复市场内幕揭秘
阅读排行
·免费代理IP(每日更新)
·DB2 9数据库专题
·关于 Apache 的几种常见应
·QQ千人好友浮出水面 会员抢
·站长手册:WIN2003下Web服
·网站投资你和我的20个自身
·140天,从做站起步到日赚1
·Fdisk分区详解
·佳能活动 免费得QQ秀
·DOS下对系统重新进行分区
专题教程
·数据恢复指南 专题
·Web服务器专题
·DB2 9数据库专题
·ghost教程 专题
·局域网技术专题
·虚拟机专题
·CDN加速技术专题
·注册表教程专题
·电脑技巧 专题
·Linux与虚拟化技术
最新文章
·Firefox出现新高危0Day漏洞
·QQ千人好友浮出水面 会员抢
·DOS下对系统重新进行分区
·Fdisk分区详解
·DOS常用命令
·dos如何进行系统配置
·dos慎用命令
·Ver、Vol、Ctty命令使用说
·Tree、Unformat、Vsafe命令
·Setver、Share、Subst命令
设为首页 - 加入收藏 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
Copyright © 2003 - 2006 XKER Inc. All Rights Reserved
新客网 版权所有