sys.dm_db_partition_stats (Transact-SQL)

返回当前数据库中每个分区的页和行计数信息。

列名

数据类型

说明

partition_id

bigint

分区 ID。在数据库中是唯一的。它的值与 sys.partitions 目录视图中的 partition_id 值相同。

object_id

int

包含该分区的表或索引视图的对象 ID。

index_id

int

包含该分区的堆或索引的 ID。

0 = 堆

1 = 聚集索引

> 1 = 非聚集索引

partition_number

int

索引或堆中从 1 开始的分区号。

in_row_data_page_count

bigint

分区中存储行内数据所用的页数。如果分区是堆的一部分,则该值为堆中的数据页数。如果分区是索引的一部分,则该值为叶级别中的页数。(未计入 B 树中非叶页的数目。)以上两种情况都未计入 IAM(索引分配映射)页。

in_row_used_page_count

bigint

用于存储和管理分区中的行内数据的总页数。该计数包括非叶 B 树页、IAM 页以及 in_row_data_page_count 列包含的全部页。

in_row_reserved_page_count

bigint

为存储和管理该分区中的行内数据而保留的总页数,包括已使用的和未使用的页。

lob_used_page_count

bigint

用于存储和管理分区中的行外 textntextimagevarchar(max)nvarchar(max)varbinary(max)xml 列的页数。包含 IAM 页。

lob_reserved_page_count

bigint

为存储和管理分区中的行外 textntextimagevarchar(max)nvarchar(max)varbinary(max)xml 列而保留的页数,包括使用的和未使用的页。包含 IAM 页。

row_overflow_used_page_count

bigint

用于保存和管理分区中行溢出 varcharnvarcharvarbinarysql_variant 列的页数。包含 IAM 页。

row_overflow_reserved_page_count

bigint

为保存和管理分区中行溢出 varcharnvarcharvarbinarysql_variant 列而保留的页数,包括已使用的和未使用的页。包含 IAM 页。

used_page_count

bigint

用于分区的总页数。计算方法为 in_row_used_page_count + lob_used_page_count + row_overflow_used_page_count

reserved_page_count

bigint

为分区保留的总页数。计算方法为 in_row_reserved_page_count + lob_reserved_page_count + row_overflow_reserved_page_count

row_count

bigint

分区中的大约行数。

注释

sys.dm_db_partition_stats 显示用于存储和管理数据库中全部分区的行内数据 LOB 数据和行溢出数据的空间的有关信息。每个分区对应一行。

作为输出数据依据的计数缓存在内存中,或存储在磁盘中的各种系统表中。

行内数据、LOB 数据以及行溢出数据表示构成分区的三个分配单元。有关分配单元的详细信息,请参阅表组织和索引组织。可以在 sys.allocation_units 目录视图中查询数据库中每个分配单元的元数据。

如果堆或索引未分区,则它由一个分区(分区号为 1)组成,因而只会为该堆或索引返回一行。有关分区的详细信息,请参阅表组织和索引组织。可以在 sys.partitions 目录视图中查询有关数据库中全部表和索引的每个分区的元数据。

可以通过求全部相关分区计数的和来获取单个表或单个索引的总计数。

权限

查询 sys.dm_db_partition_stats 动态管理视图要求具备 VIEW DATABASE STATE 权限。有关动态管理视图权限的详细信息,请参阅动态管理视图和函数 (Transact-SQL)

示例

A. 返回数据库中全部索引和堆的全部分区的所有计数

以下示例演示了 AdventureWorks2008R2 数据库中全部索引和堆的全部分区的所有计数。

USE AdventureWorks2008R2;
GO
SELECT * FROM sys.dm_db_partition_stats;
GO

B. 返回表及其索引的全部分区的所有计数

以下示例演示了 HumanResources.Employee 表及其索引的全部分区的所有计数。

USE AdventureWorks2008R2;
GO
SELECT * FROM sys.dm_db_partition_stats 
WHERE object_id = OBJECT_ID('HumanResources.Employee');
GO

C. 返回堆或聚集索引使用的总页数和总行数

以下示例返回 HumanResources.Employee 表的堆或聚集索引使用的总页数和总行数。因为默认情况不对 Employee 表分区,请注意和仅包含一个分区。

USE AdventureWorks2008R2;
GO
SELECT SUM(used_page_count) AS total_number_of_used_pages, 
    SUM (row_count) AS total_number_of_rows 
FROM sys.dm_db_partition_stats
WHERE object_id=OBJECT_ID('HumanResources.Employee')    AND (index_id=0 or index_id=1);
GO