通行证: 用户 密码 域名空间  下载中心 社区论坛 信息公告 MY小屋
联系我们
设为首页
加入收藏

 

QQ,ASP,PHP,JSP,XML,SQL,.Net,编程 程序 网页图象 建站经验 私服
首页 | 新闻资讯 | 编程开发 | 网页设计 | 图形图象 | 网络媒体 | 网站模板 | 数 据 库 | 投稿
论坛 | 操作系统 | 系统优化 | 网络安全 | 黑客技术 | 硬件学堂 | 硬件报价 | 服 务 器 | 地图
专题 | 应用软件 | 聊天通讯 | Q Q 专栏 | 建站经验 | 在线工具 | 站长Club | 注 册 表 | 旧版
社会 | 游戏娱乐 | 设计欣赏 | 疑难解答 | 社区论坛 | 韩国素材 | 素材图库 | 广告服务 | 服务
当前位置:首页>>数 据 库>>Oracle>>正文 新版上线![旧版]
注:打开慢时请稍等

Oracle如何精确计算row的大小

http://www.iyit.net  日期:2006-6-6 9:18:06  来源:  点击:
参加讨论第一步:计算整个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监控数据库性能的SQL汇总
下一篇:ORACLE碎片整理(2)
转载请注明来源:www.iyit.net
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。

 相关文章
最新更新 热点排行 推荐新闻
ORACLE碎片整理(1)
ORACLE碎片整理(2)
Oracle如何精确计算row的大小
oracle监控数据库性能的SQL汇总
Oracle logminer使用方法总结
ORACLE碎片整理(1)
ORACLE碎片整理(2)
Oracle如何精确计算row的大小
oracle监控数据库性能的SQL汇总
Oracle logminer使用方法总结
某外企SQL Server面试题
同步两个SQLServer数据库
SQL Server:错误18483
SQL2005其中三个版本的比较
远程连接sql server 2000服务器的解决
VB程序如何访问数据库
VB程序如何连接数据库
Oracle作业(JOB)更新next_date的探讨
PL/SQL过程
VB+Oracle 9i如何构建开发和运行的环境
QQ最新版下载 2006 beta2 体验新感受 
QQ密码破解程序
Windows XP专业版IIS连接数的更改
QQ密码本地破解
Office2007简体中文版浮出水面 美图抢
Visual Basic 概述
解决暴风影音无法渲染此文件的难题
解决Windows中的explorer.exe出错
exeplorer.exe错误的问题的总结、解决
一个好汉N个帮 Word实用插件集锦
巧用ACDSee 8.0截取QQ表情每一帧
解除瑞星 诺顿遗留下的杀毒兼容问题
第一款开源AJAX安全扫描工具Sprajax
WinRAR人性化功能揭密
在ASP.NET中防止注入攻击
用ASP.NET开发Web服务的五则技巧
Linux操作系统12则经典应用技巧
浅谈Linux优化及安全配置的个人体会
解决局域网不能互相访问之全攻略
WIN 2000简单的入侵常识
 友情链接
设置首 页 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
Copyrights © 2004-2006 iYiT.Net All Rights Reserved.
网站合作、广告联系QQ:147007642、466949678
易特网络技术 点击这里给我发消息