日期:2014-02-01 浏览次数:20553 次
Microsoft® SQL Server™ 2000 收集关于存储在数据库中的索引和列数据的统计信息。SQL Server 查询优化器使用这些统计信息来选择用于执行 INSERT、SELECT、DELETE 或 UPDATE 查询的最有效方案。本文说明了收集的数据类型、数据的存储位置以及用于创建、更新与删除统计的命令。默认情况下,SQL Server 2000 会自动创建和更新统计(当此类操作有用时)。本文也概括介绍了如何在不同的级别(索引、表和数据库)上更改这些默认值。www.9246369iTbulo.comtPCRkq2
SQL Server 2000 既收集关于单个列的统计信息(单列统计),也收集关于成组的列的统计信息(多列统计)。关于一个统计对象的所有信息存储在 SYSINDEXES 表中一行的多个列中。计算列以及数据类型为 ntext、text 或 image 的列不能被指定为统计列。组成一个统计集的所有列的总宽度不能超过 900 字节。www.9246369iTbulo.comtPCRkq2
注意: 直方图是给定列的最多 200 个值的集合。给定列中的所有值(如果通过抽样来收集统计信息,则为选定的值)会被排序;排序后序列最多会划分为 199 个间隔,以便得到最有效的统计。一般,这些间距的大小并不相等。以下数值与直方图的每个步长存储在一起。www.9246369iTbulo.comtPCRkq2
表 1:直方图的值www.9246369iTbulo.comtPCRkq2
RANGE_HI_KEY | 键值 |
EQ_ROWS | 指定与 RANGE_HI_KEY 精确相等的行数。 |
RANGE_ROWS | 指定区间中的行数。(这些行小于这个 RANGE_HI_KEY,但大于上一个较小的区间键值)。 |
DENSITY | 指定 1/n,其中 n 表示区间中互不相同的值的数目。 |
使用 dbcc show_statistics 命令时显示的是两个导出值而不是 DENSITY 信息。www.9246369iTbulo.comtPCRkq2
表 2:用两个导出值显示 dbcc show_statistics 的直方图www.9246369iTbulo.comtPCRkq2
DISTINCT_RANGE_ROWS | 指定此区间中互不相同的行的数目(不算 RANGE_HI_KEY 值本身);DISTINCT_RANGE_ROWS = 1 / DENSITY。 |
AVG_RANGE_ROWS | 区间中每个特定值的平均行数;AVG_RANGE_ROWS = DENSITY * RANGE_ROWS。 |
SQL Server 2000 中的直方图只用于单个列、多列统计中的第一列或者索引。www.9246369iTbulo.comtPCRkq2
SQL Server 2000 按照三个步骤从排序后的列值集合生成直方图。第一步,最多收集 200 个 RANGE_HI_KEY、EQ_ROWS、RANGE_ROWS 和 DISTINC_RANGE_ROWS 的值。第二步,对每个其他的列值进行处理:该值或者被添加到上一个区间中(对值进行排序),或者创建一个新区间。如果是创建一个新区间,则两个现有的相邻区间会合并到一个区间中。SQL Server 2000 通过密度信息来选择要合并的区间,使密度最接近的两个相邻区间被合并,从而将信息的损失降到最低程度。第三步,合并更多的密度接近的区间。因此,即使列中的唯一值个数超过 200,直方图的步数也可能会小于 200。www.9246369iTbulo.comtPCRkq2
如果通过抽样来生成直方图,那么 RANGE_ROWS、EQ_ROWS、DISTINCT_RANGE_ROWS 和 AVG_RANGE_ROWS 的值将为估计值,因此它们不必都是整数。www.9246369iTbulo.comtPCRkq2
密度是关于给定列或列的组合中重复项数目的信息,其计算公式为 1/(互不相同的值的数目)。如果在相等条件判断表达式中使用了某个列,则会使用从直方图导出的密度来估算符合条件的行数。直方图通常用于估算不等条件判断表达式。www.9246369iTbulo.comtPCRkq2