ImageVerifierCode 换一换
格式:DOCX , 页数:11 ,大小:30.79KB ,
资源ID:7274124      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/7274124.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(估计数据库占用磁盘空间.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

估计数据库占用磁盘空间.docx

1、估计数据库占用磁盘空间1.估计数据库占用磁盘空间的大小1.1 估计堆的大小1.1.1指定表中显示的行数Num_Rows = 表中的行数1.1.2指定固定长度和可变长度列的数量计算存储所需的空间,计算每组列在数据行中所占据的空间。列的大小取决于数据类型和长度规定。有关详细信息,请参阅数据类型(数据库引擎)。Num_Cols = 总列数(固定长度和可变长度)Fixed_Data_Size = 所有固定长度列的总字节大小Num_Variable_Cols = 可变长度列的数量Max_Var_Size = 所有可变长度列的最大总字节大小1.1.3保留行中称为 Null 位图的部分以管理列的为空性Nul

2、l_Bitmap = 2 + (Num_Cols + 7) / 8)只应使用该表达式的整数部分。而放弃所有余数。1.1.4计算可变长度数据的大小如果表中有可变长度列,请确定在行中存储这些列需使用的空间:Variable_Data_Size = 2 + (Num_Variable_Cols x 2) + Max_Var_Size添加到 Max_Var_Size 中的字节用于跟踪每个可变长度列。此公式假设所有可变长度列均百分之百充满。如果预计可变长度列占用的存储空间比例较低,则可以按照该比例调整 Max_Var_Size 值,从而对整个表大小得出一个更准确的估计。1.1.5 计算总的行大小Row_

3、Size = Fixed_Data_Size + Variable_Data_Size + Null_Bitmap + 41.1.6 计算每页的行数(每页有 8096 个可用字节)Rows_Per_Page = 8096 / (Row_Size + 2)因为行不跨页,所以每页的行数应向下舍入到最接近的整数。公式中的数值 2 是计算行数时引入的行大小余量。1.1.7 计算存储所有行所需的页数Num_Pages = Num_Rows / Rows_Per_Page估计的页数应向上舍入到最接近的整数。1.1.8 计算在堆中存储数据所需的空间量(每页的总字节为 8192)堆大小(字节)= 8192 x

4、 Num_Pages1.2 估计聚集索引的大小1.2.1 计算存储聚集索引叶级数据所用的空间1.2.1.1 指定表中显示的行数Num_Rows = 表中的行数1.2.1.2 指定固定长度和可变长度列的数量计算每组列在数据行中所占据的空间。列的大小取决于数据类型和长度规定。有关详细信息,请参阅数据类型(数据库引擎)。Num_Cols = 总列数(固定长度和可变长度)Fixed_Data_Size = 所有固定长度列的总字节大小Num_Variable_Cols = 可变长度列的数量Max_Var_Size = 所有可变长度列的最大字节大小1.2.1.3 唯一标识符如果聚集索引不唯一,则请说明“唯

5、一标识符”列:唯一标识符是可为 Null 的可变长度列。在具有非唯一键值的行中,它非 Null 而且大小为 4 个字节。此值是索引键的一部分,用于确保每一行都具有唯一的键值。Num_Cols = Num_Cols + 1Num_Variable_Cols = Num_Variable_Cols + 1Max_Var_Size = Max_Var_Size + 4这些修改假定所有值都不是唯一的。1.2.1.4 Null 位图保留行中称为 Null 位图的部分以管理列的为空性。计算其大小:Null_Bitmap = 2 + (Num_Cols + 7) / 8)仅使用上述表达式中的整数部分,而放弃

6、所有余数。1.2.1.5 可变长度数据如果表中有可变长度列,请确定在行中存储这些列需使用的空间:Variable_Data_Size = 2 + (Num_Variable_Cols x 2) + Max_Var_Size添加到 Max_Var_Size 中的字节用于跟踪每个可变列。此公式假设所有可变长度列均百分之百充满。如果预计可变长度列占用的存储空间比例较低,则可以按照该比例调整 Max_Var_Size 值,从而对整个表大小得出一个更准确的估计。如果没有可变长度列,请将 Variable_Data_Size 设置为 0。1.2.1.6 计算总的行大小Row_Size = Fixed_Da

7、ta_Size + Variable_Data_Size + Null_Bitmap + 4值 4 是数据行的行标题的开销。1.2.1.7每页的行数(每页有 8096 个可用字节):Rows_Per_Page = 8096 / (Row_Size + 2)因为行不跨页,所以每页的行数应向下舍入到最接近的整数。公式中的数值 2 是计算行数时引入的行大小余量。1.2.1.8 每页保留的空行数根据指定的填充因子计算每页保留的空行数:Free_Rows_Per_Page = 8096 x (100 - Fill_Factor) / 100) / (Row_Size + 2)计算中使用的填充因子为整数值

8、,而不是百分比。因为行不跨页,所以每页的行数应向下舍入到最接近的整数。填充因子增大时,每页将存储更多的数据,因此页数将减少。公式中的数值 2 是计算行数时引入的行大小余量。1.2.1.9 存储所有行所需的页数Num_Leaf_Pages = Num_Rows / (Rows_Per_Page - Free_Rows_Per_Page)估计的页数应向上舍入到最接近的整数。1.2.1.10 叶级别中存储数据所需的空间大小(每页共有 8192 个字节):Leaf_space_used = 8192 x Num_Leaf_Pages1.2.2 计算存储聚集索引的索引信息所用的空间1.2.2.1 索引键

9、中固定长度和可变长度列指定索引键中固定长度和可变长度列的数量,并计算存储所需的空间:索引键列可以包括固定长度和可变长度列。若要估计内部级别索引行的大小,请计算每组列在索引行中所占据的空间。列的大小取决于数据类型和长度规定。有关详细信息,请参阅数据类型(数据库引擎)。Num_Key_Cols = 总键列数(固定长度和可变长度)Fixed_Key_Size = 所有固定长度键列的总字节大小Num_Variable_Key_Cols = 可变长度键列的数量Max_Var_Key_Size = 所有可变长度键列的最大字节大小1.2.2.2 唯一标识符如果索引不唯一,则请说明所需的任意唯一标识符:唯一标

10、识符是可为 Null 的可变长度列。它将是非 Null 的,在具有非唯一索引键值的行中的大小是 4 个字节。此值是索引键的一部分,用于确保每一行都具有唯一的键值。Num_Key_Cols = Num_Key_Cols + 1Num_Variable_Key_Cols = Num_Variable_Key_Cols + 1Max_Var_Key_Size = Max_Var_Key_Size + 4这些修改假定所有值都不是唯一的。1.2.2.3 Null 位图计算 Null 位图大小:如果索引键中有允许为 Null 的列,则索引行的一部分将为 Null 位图保留。计算其大小:Index_Null

11、_Bitmap = 2 + (索引行中的列数 + 7) / 8)仅应使用上述表达式中的整数部分,而放弃所有余数。如果没有可为 Null 的键列,请将 Index_Null_Bitmap 设置为 0。1.2.2.4 可变长度数据如果索引中有可变长度列,请确定在索引行中存储这些列需使用的空间:Variable_Key_Size = 2 + (Num_Variable_Key_Cols x 2) + Max_Var_Key_Size添加到 Max_Var_Key_Size 中的字节用于跟踪每个可变长度列。此公式假设所有可变长度列均百分之百充满。如果预计可变长度列占用的存储空间比例较低,则可以按照该比

12、例调整 Max_Var_Key_Size 值,从而对整个表大小得出一个更准确的估计。如果没有可变长度列,请将 Variable_Key_Size 设置为 0。1.2.2.5 索引行大小Index_Row_Size = Fixed_Key_Size + Variable_Key_Size + Index_Null_Bitmap + 1(对应于索引行的行标题开销)+ 6(对应于子页 ID 指针)。1.2.2.6每页的索引行数(每页有 8096 个可用字节)Index_Rows_Per_Page = 8096 / (Index_Row_Size + 2)因为索引行不能跨页,所以每页的索引行数应向下舍

13、入到最接近的整数。公式中的 2 是计算行数时引入的行大小余量。1.2.2.7索引中的级别数Non-leaf_Levels = 1 + log Index_Rows_Per_Page (Num_Leaf_Pages / Index_Rows_Per_Page)将此值向上舍入到最接近的整数。此值不包括聚集索引的叶级别。1.2.2.8索引中的非叶页数计算索引中的非叶页数:Num_Index_Pages = Level (Num_Leaf_Pages / (Index_Rows_Per_PageLevel)其中,1 = Level = Non-leaf_Levels将每个被加数向上舍入到最接近的整数。

14、由于是个简单示例,请考虑使用 Num_Leaf_Pages = 1000 和 Index_Rows_Per_Page = 25 的索引。页级别以上的第一个索引级别存储 1000 个索引行,即每个叶页一个索引行,每页可以包括 25 个索引行。这意味着存储这 1000 个索引行需要 40 页。下一级索引必须存储 40 行。这意味着需要 2 页。最后一级索引必须存储 2 行。这意味着需要 1 页。这就提供了 43 个非叶索引页。如果将这些数用到前面的公式中,结果如下:Non-leaf_Levels = 1 + log25 (1000 / 25) = 3Num_Index_Pages = 1000/(

15、253)+ 1000/(252) + 1000/(251) = 1 + 2 + 40 = 43,这是上面的示例中所述的页数。1.2.2.9索引的大小(每页总共有 8192 个字节):Index_Space_Used = 8192 x Num_Index_Pages1.2.3 对计算出的值求和聚集索引大小(字节)= Leaf_Space_Used + Index_Space_used此计算不考虑以下因素:(1)分区:分区的空间开销很小,但是计算复杂。是否包括它并不重要。(2)分配页:至少有一个 IAM 页用于跟踪为堆分配的页,但是空间开销很小,并且没有算法可以精确地计算出要使用的 IAM 页数。

16、(3)大型对象 (LOB) 值:精确确定存储 LOB 数据类型 varchar(max)、varbinary(max)、nvarchar(max)、text、ntext、xml 和 image 值所用的空间量的算法非常复杂。只需加上所期望的 LOB 值的平均大小,再乘以 Num_Rows,然后再加上聚集索引的总大小就可以了。(4)压缩:无法预先计算压缩索引的大小。1.3 估计非聚集索引的大小1.3.1 计算相关值1.3.1.1表中显示的行数Num_Rows = 表中的行数1.3.1.2索引键中固定长度和可变长度列的数量指定索引键中固定长度和可变长度列的数量,并计算存储所需的空间:索引键列可以包

17、括固定长度和可变长度列。若要估计内部级别索引行的大小,请计算每组列在索引行中所占据的空间。列的大小取决于数据类型和长度规定。有关详细信息,请参阅数据类型(数据库引擎)。Num_Key_Cols = 总键列数(固定长度和可变长度)Fixed_Key_Size = 所有固定长度键列的总字节大小Num_Variable_Key_Cols = 可变长度键列的数量Max_Var_Key_Size = 所有可变长度键列的最大字节大小1.3.1.3数据行定位符如果索引不是唯一的,对所需的数据行定位符说明如下:如果非聚集索引不是唯一的,数据行定位符将与非聚集索引键组合使用,以便为每一行生成唯一的键值。如果非聚

18、集索引在堆上,则数据行定位符是堆 RID。其大小是 8 个字节。Num_Key_Cols = Num_Key_Cols + 1Num_Variable_Key_Cols = Num_Variable_Key_Cols + 1Max_Var_Key_Size = Max_Var_Key_Size + 8如果非聚集索引在聚集索引之上,则数据行定位符是聚集键。必须与非聚集索引键结合使用的列是聚集键中的以下列:不在非聚集索引键列集中的列。Num_Key_Cols = Num_Key_Cols + 不在非聚集索引键列集中的聚集键列数(如果聚集索引不唯一,则 + 1)Fixed_Key_Size = Fi

19、xed_Key_Size + 不在非聚集索引键列集中的固定长度聚集键列的总字节大小Num_Variable_Key_Cols = Num_Variable_Key_Cols + 不在非聚集索引键列集中的可变长度聚集键列数(如果聚集索引不唯一,则 + 1)Max_Var_Key_Size = Max_Var_Key_Size + 不在非聚集索引键列集中的可变长度聚集键列的最大字节大小(如果聚集索引不唯一,则 + 4)1.3.1.4空位图可以保留行的一部分(称为“空位图”),以管理列的为空性。计算其大小:如果索引键中有可为 Null 的列(包括步骤 1.3 中所述的所有必要的聚集键列),则保留索引

20、行的一部分,以用于 Null 位图。Index_Null_Bitmap = 2 + (索引行中的列数 + 7) / 8)仅应使用上述表达式中的整数部分,而放弃所有余数。如果没有可为 Null 的键列,请将 Index_Null_Bitmap 设置为 0。1.3.1.5 可变长度数据计算可变长度数据大小:如果索引键中有可变长度的列(包括所有必要的聚集索引键列),请确定存储索引行中的这些列需使用的空间:Variable_Key_Size = 2 + (Num_Variable_Key_Cols x 2) + Max_Var_Key_Size添加到 Max_Var_Key_Size 中的字节用于跟踪

21、每个可变列。此公式假定所有可变长度列均百分之百充满。如果预计可变长度列占用的存储空间比例较低,则可以按照该比例调整 Max_Var_Key_Size 值,从而对整个表大小得出一个更准确的估计。如果没有可变长度列,请将 Variable_Key_Size 设置为 0。1.3.1.6 索引行大小计算索引行大小:Index_Row_Size = Fixed_Key_Size + Variable_Key_Size + Index_Null_Bitmap + 1(对应于索引行的行标题开销)+ 6(对应于子页 ID 指针)1.3.1.7 每页的索引行数计算每页的索引行数(每页有 8096 个可用字节):

22、Index_Rows_Per_Page = 8096 / (Index_Row_Size + 2)因为索引行不能跨页,所以每页的索引行数应向下舍入到最接近的整数。公式中的 2 是计算行数时引入的行大小余量。1.3.2 计算用于存储叶级中的索引信息的空间1.3.2.1 固定长度列和可变长度列如果非聚集索引没有任何包含列:Num_Leaf_Cols = Num_Key_ColsFixed_Leaf_Size = Fixed_Key_SizeNum_Variable_Leaf_Cols = Num_Variable_Key_ColsMax_Var_Leaf_Size = Max_Var_Key_Si

23、ze如果非聚集索引确实具有包含列,则对步骤 1 中的值加上适当的值。列的大小取决于数据类型和长度规定。有关详细信息,请参阅数据类型(数据库引擎)。Num_Leaf_Cols = Num_Key_Cols + 包含列数Fixed_Leaf_Size = Fixed_Key_Size + 固定长度包含列的总字节大小Num_Variable_Leaf_Cols = Num_Variable_Key_Cols + 可变长度包含列数Max_Var_Leaf_Size = Max_Var_Key_Size + 可变长度包含列的最大字节大小1.3.2.2 数据行定位符如果非聚集索引不是唯一的。转到下一步。如

24、果非聚集索引是唯一的,则必须在叶级的所有行中说明数据行定位符。如果非聚集索引在堆上,则数据行定位符是堆 RID(大小为 8 字节)。Num_Leaf_Cols = Num_Leaf_Cols + 1Num_Variable_Leaf_Cols = Num_Variable_Leaf_Cols + 1Max_Var_Leaf_Size = Max_Var_Leaf_Size + 8如果非聚集索引在聚集索引之上,则数据行定位符是聚集键。必须与非聚集索引键结合使用的列是聚集键中的以下列:不在非聚集索引键列集中的列。Num_Leaf_Cols = Num_Leaf_Cols + 不在非聚集索引键列集中

25、的聚集键列数(如果聚集索引不唯一,则 + 1)Fixed_Leaf_Size = Fixed_Leaf_Size + 不在非聚集索引键列集中的固定长度聚集键列数Num_Variable_Leaf_Cols = Num_Variable_Leaf_Cols + 不在非聚集索引键列集中的可变长度聚集键列数(如果聚集索引不唯一,则 + 1)Max_Var_Leaf_Size = Max_Var_Leaf_Size + 不在非聚集索引键列集中的可变长度聚集键列的字节大小(如果聚集索引不唯一,则 + 4)1.3.2.3 Null 位图计算 Null 位图大小:Leaf_Null_Bitmap = 2 +

26、 (Num_Leaf_Cols + 7) / 8)仅应使用上述表达式中的整数部分,而放弃所有余数。1.3.2.4 可变长度数据计算可变长度数据大小:如果索引键中有可变长度的列,请确定存储索引行中的这些列需使用的空间:Variable_Leaf_Size = 2 + (Num_Variable_Leaf_Cols x 2) + Max_Var_Leaf_Size添加到Max_Var_Key_Size中的字节用于跟踪每个可变列。此公式假定所有可变长度列均百分之百充满。如果预计可变长度列占用的存储空间比例较低,则可以按照该比例调整 Max_Var_Leaf_Size 值,从而对整个表大小得出一个更准

27、确的估计。如果没有可变长度的列,则将 Variable_Leaf_Size 设置为 0。1.3.2.5 索引行大小计算索引行大小:Leaf_Row_Size = Fixed_Leaf_Size + Variable_Leaf_Size + Leaf_Null_Bitmap + 1 (对应于索引行的行标题开销)+ 6(对应于子页 ID 指针)1.3.2.6 每页的索引行数(每页有 8096 个可用字节):Leaf_Rows_Per_Page = 8096 / (Leaf_Row_Size + 2)因为索引行不能跨页,所以每页的索引行数应向下舍入到最接近的整数。公式中的 2 是计算行数时引入的行大

28、小余量。1.3.2.7 每页保留的空行数根据指定的填充因子计算每页保留的空行数:Free_Rows_Per_Page = 8096 x (100 - Fill_Factor) / 100) / (Leaf_Row_Size + 2)计算中使用的填充因子为整数值,而不是百分比。因为行不跨页,所以每页的行数应向下舍入到最接近的整数。填充因子增大时,每页将存储更多的数据,因此页数将减少。公式中的 2 是计算行数时引入的行大小余量。1.3.2.8 存储所有行所需的页数计算存储所有行所需的页数:Num_Leaf_Pages = Num_Rows / (Leaf_Rows_Per_Page - Free_

29、Rows_Per_Page)估计的页数应向上舍入到最接近的整数。1.3.2.9 索引的大小(每页总共有 8192 个字节):Leaf_Space_Used = 8192 x Num_Leaf_Pages1.3.3 计算用于存储非叶级中的索引信息的空间1.3.3.1 索引中的非叶级数计算索引中的非叶级数:将此值向上舍入到最接近的整数。此值不包括非聚集索引的叶级别。1.3.3.2 索引中的非叶页数计算索引中的非叶页数:将每个被加数向上舍入到最接近的整数。由于是个简单示例,请考虑使用 Num_Leaf_Pages = 1000 和 Index_Rows_Per_Page = 25 的索引。页级别以上

30、的第一个索引级别存储 1000 个索引行,即每个叶页一个索引行,每页可以包括 25 个索引行。这意味着存储这 1000 个索引行需要 40 页。下一级索引必须存储 40 行。这意味着需要 2 页。最后一级索引必须存储 2 行。这意味着需要 1 页。这就产生了 43 个非叶索引页。如果将这些数用到前面的公式中,结果如下:,这是上面的示例中所述的页数。1.3.3.3 索引大小计算索引的大小(每页总共有 8192 个字节):Index_Space_Used = 8192 x Num_Index_Pages1.3.4 对计算出的值求和对从前面两个步骤中得到的值求和:Nonclustered index size (bytes) = Leaf_Space_Used + Index_Space_used此计算不考虑以下因素和以上提到的相同。

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1