好文档就是一把金锄头!
欢迎来到金锄头文库![会员中心]
电子文档交易市场
安卓APP | ios版本
电子文档交易市场
安卓APP | ios版本

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

11页
  • 卖家[上传人]:飞***
  • 文档编号:47681554
  • 上传时间:2018-07-04
  • 文档格式:PDF
  • 文档大小:77.18KB
  • / 11 举报 版权申诉 马上下载
  • 文本预览
  • 下载提示
  • 常见问题
    • 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 位图的部分以管理列的为空性Null_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_Size = Fixed_Data_Size + Variable_Data_Size + Null_Bitmap + 4 1.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 Num_Pages 1.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 唯一标识符如果聚集索引不唯一,则请说明“唯一标识符”列: 唯一标识符是可为Null 的可变长度列在具有非唯一键值的行中,它非 Null 而且大小为4 个字节此值是索引键的一部分,用于确保每一行都具有唯 一的键值 Num_Cols = Num_Cols + 1 Num_Variable_Cols = Num_Variable_Cols + 1 Max_Var_Size = Max_Var_Size + 4 这些修改假定所有值都不是唯一的1.2.1.4 Null 位图保留行中称为Null 位图的部分以管理列的为空性计算其大小: Null_Bitmap = 2 + ((Num_Cols + 7) / 8) 仅使用上述表达式中的整数部分,而放弃所有余数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 设置为 01.2.1.6 计算总的行大小Row_Size = Fixed_Data_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) 计算中使用的填充因子为整数值,而不是百分比 因为行不跨页, 所以每页 的行数应向下舍入到最接近的整数。

      填充因子增大时,每页将存储更多的数据, 因此页数将减少公式中的数值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_Pages 1.2.2 计算存储聚集索引的索引信息所用的空间1.2.2.1 索引键中固定长度和可变长度列指定索引键中固定长度和可变长度列的数量,并计算存储所需的空间: 索引键列可以包括固定长度和可变长度列若要估计内部级别索引行的大 小,请计算每组列在索引行中所占据的空间列的大小取决于数据类型和长度规 定有关详细信息,请参阅数据类型(数据库引擎) Num_Key_Cols = 总键列数(固定长度和可变长度) Fixed_Key_Size = 所有固定长度键列的总字节大小 Num_Variable_Key_Cols = 可变长度键列的数量 Max_Var_Key_Size = 所有可变长度键列的最大字节大小1.2.2.2 唯一标识符如果索引不唯一,则请说明所需的任意唯一标识符: 唯一标识符是可为Null 的可变长度列。

      它将是非Null 的,在具有非唯一 索引键值的行中的大小是4 个字节此值是索引键的一部分,用于确保每一行 都具有唯一的键值 Num_Key_Cols = Num_Key_Cols + 1 Num_Variable_Key_Cols = Num_Variable_Key_Cols + 1 Max_Var_Key_Size = Max_Var_Key_Size + 4 这些修改假定所有值都不是唯一的1.2.2.3 Null 位图计算 Null 位图大小: 如果索引键中有允许为Null 的列, 则索引行的一部分将为Null 位图保留 计算其大小:Index_Null_Bitmap = 2 + ((索引行中的列数+ 7) / 8) 仅应使用上述表达式中的整数部分,而放弃所有余数 如果没有可为Null 的键列,请将Index_Null_Bitmap 设置为 01.2.2.4 可变长度数据如果索引中有可变长度列,请确定在索引行中存储这些列需使用的空间: Variable_Key_Size = 2 + (Num_Variable_Key_Cols x 2) + Max_Var_Key_Size 添加到Max_Var_Key_Size 中的字节用于跟踪每个可变长度列。

      此公式假 设所有可变长度列均百分之百充满 如果预计可变长度列占用的存储空间比例较 低,则可以按照该比例调整Max_Var_Key_Size 值,从而对整个表大小得出一 个更准确的估计 如果没有可变长度列,请将Variable_Key_Size 设置为 01.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) 因为索引行不能跨页, 所以每页的索引行数应向下舍入到最接近的整数公 式中的 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 将每个被加数向上舍入到最接近的整数由于是个简单示例,请考虑使用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) = 3 Num_Index_Pages = 1000/(253)+ 1000/(252) + 1000/(251) = 1 + 2 + 40 = 43, 这是上面的示例中所述的页数。

      1.2.2.9 索引的大小(每页总共有8192 个字节) : Index_Space_Used = 8192 x Num_Index_Pages 1.2.3 对计算出的值求和聚集索引大小(字节) = Leaf_Space_Used + Index_Space_used 此计算不考虑以下因素: (1)分区:分区的空间开销很小,但是计算复杂是否包括它并不重要 (2)分配页:至少有一个IAM 页用于跟踪为堆分配的页,但是空间开销 很小,并且没有算法可以精确地计算出要使用的IAM 页数 (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 索引键中固定长度和可变长度列的数量指定索引键中固定长度和可变长度列的数量,并计算存储所需的空间: 索引键列可以包括固定长度和可变长度列。

      若要估计内部级别索引行的大小,请计算每组列在索引。

      点击阅读更多内容
      关于金锄头网 - 版权申诉 - 免责声明 - 诚邀英才 - 联系我们
      手机版 | 川公网安备 51140202000112号 | 经营许可证(蜀ICP备13022795号)
      ©2008-2016 by Sichuan Goldhoe Inc. All Rights Reserved.