sys.dm_db_index_operational_stats (Transact-SQL)

适用于:SQL ServerAzure SQL 数据库Azure SQL 托管实例

返回数据库中表或索引的每个分区的当前较低级别 I/O、锁定、闩锁和访问方法活动。

内存优化索引不会出现在此 DMV 中。

注意

sys.dm_db_index_operational_stats不返回有关内存优化索引的信息。 有关内存优化索引使用的信息,请参阅sys.dm_db_xtp_index_stats(Transact-SQL)。

Transact-SQL 语法约定

语法

sys.dm_db_index_operational_stats (    
    { database_id | NULL | 0 | DEFAULT }    
  , { object_id | NULL | 0 | DEFAULT }    
  , { index_id | 0 | NULL | -1 | DEFAULT }    
  , { partition_number | NULL | 0 | DEFAULT }    
)    

参数

database_id |NULL |0 |违约

数据库 ID。 database_id较小。 有效的输入包括数据库的 ID 号、NULL、0 或 DEFAULT。 默认值为 0。 在此上下文中,NULL、0 和 DEFAULT 是等效值。

指定 NULL 以返回 SQL Server 实例中的所有数据库的信息。 如果为 database_id指定 NULL,则还必须为 object_idindex_idpartition_number指定 NULL。

你可以指定内置函数 DB_ID

object_id |NULL |0 |违约

索引所打开的表或视图的对象 ID。 object_id为 int

有效的输入包括表和视图的 ID 号、NULL、0 或 DEFAULT。 默认值为 0。 在此上下文中,NULL、0 和 DEFAULT 是等效值。

指定 NULL 可返回指定数据库中的所有表和视图的缓存信息。 如果为 object_id指定 NULL,则还必须为 index_idpartition_number指定 NULL。

index_id | 0 |NULL |-1 |违约

索引的 ID。 index_id为 int。有效输入是索引的 ID 号,如果object_id是堆、NULL、-1 或 DEFAULT,则为 0。 默认值为 -1。在此上下文中,NULL、-1 和 DEFAULT 是等价值。

指定 NULL 可返回基表或视图的所有索引的缓存信息。 如果为 index_id指定 NULL,则还必须为 partition_number指定 NULL。

partition_number |NULL |0 |违约

对象中的分区号。 partition_numberint。有效输入是索引或堆、NULL、0 或 DEFAULT 的 partition_number。 默认值为 0。 在此上下文中,NULL、0 和 DEFAULT 是等效值。

指定 NULL 可返回索引或堆的所有分区的缓存信息。

partition_number 基于 1。 非分区索引或堆partition_number设置为 1。

返回的表

列名称 数据类型 描述
database_id smallint 数据库 ID。

在 Azure SQL 数据库中,这些值在单一数据库或弹性池中是唯一的,但在逻辑服务器中不是唯一的。
object_id int 表或视图的 ID。
index_id int 索引或堆的 ID。

0 = 堆
partition_number int 索引或堆中从 1 开始的分区号。
hobt_id bigint 适用于: SQL Server 2016(13.x)及更高版本,Azure SQL 数据库。

跟踪列存储索引的内部数据的数据堆或 B 树行集的 ID。

NULL - 这不是内部列存储行集。

有关详细信息,请参阅 sys.internal_partitions(Transact-SQL)
leaf_insert_count bigint 叶级插入的累积计数。
leaf_delete_count bigint 叶级删除的累积计数。 对于第一个未标记为虚影的已删除记录,leaf_delete_count只会递增。 对于首先虚影的已删除记录, leaf_ghost_count 会改为递增。
leaf_update_count bigint 叶级更新的累积计数。
leaf_ghost_count bigint 标记为删除但尚未删除的叶级行的累积计数。 此计数不包括立即删除且未标记为虚影的记录。 清除线程会按设置的间隔删除这些行。 此值不包括由于未完成的快照隔离事务而保留的行。
nonleaf_insert_count bigint 叶级以上的插入累积计数。

0 = 堆或列存储
nonleaf_delete_count bigint 叶级以上的删除累积计数。

0 = 堆或列存储
nonleaf_update_count bigint 叶级以上的更新累积计数。

0 = 堆或列存储
leaf_allocation_count bigint 索引或堆中的叶级页分配的累积计数。

对于索引,页分配与页拆分对应。
nonleaf_allocation_count bigint 叶级以上由页拆分引起的页分配的累积计数。

0 = 堆或列存储
leaf_page_merge_count bigint 叶级页合并的累积计数。 对于列存储索引,始终为 0。
nonleaf_page_merge_count bigint 叶级以上页合并的累积计数。

0 = 堆或列存储
range_scan_count bigint 从索引或堆开始的范围和表扫描的累积计数。
singleton_lookup_count bigint 对索引或堆的单行检索的累积计数。
forwarded_fetch_count bigint 通过前推记录提取的行计数。

0 = 索引
lob_fetch_in_pages bigint 从 LOB_DATA 分配单元检索到的大型对象 (LOB) 页的累积计数。 这些页面包含存储在文本、ntext、imagevarchar(max)、nvarchar(max)varbinary(max)xml列中的数据。 有关详细信息,请参阅 数据类型 (Transact-SQL)
lob_fetch_in_bytes bigint 检索到的 LOB 数据字节数的累积计数。
lob_orphan_create_count bigint 为大容量操作创建的孤立 LOB 值的累积计数。

0 = 非聚集索引
lob_orphan_insert_count bigint 大容量操作期间插入的孤立 LOB 值的累积计数。

0 = 非聚集索引
row_overflow_fetch_in_pages bigint 从 ROW_OVERFLOW_DATA 分配单元检索到的行溢出数据页数的累积计数。

这些页面包含存储在 varchar(n)、nvarchar(n)varbinary(n)已下推行sql_variant列中的数据。
row_overflow_fetch_in_bytes bigint 检索到的行溢出数据字节数的累积计数。
column_value_push_off_row_count bigint 已推出行外以使插入或更新的行可容纳在页中的 LOB 数据和行溢出数据的列值累积计数。
column_value_pull_in_row_count bigint 已请求到行内的 LOB 数据和行溢出数据的列值的累积计数。 当更新操作释放记录中的空间,并提供将一个或多个行外值从 LOB_DATA 或 ROW_OVERFLOW_DATA 分配单元请求到 IN_ROW_DATA 分配单元中的机会时,就会出现此计数。
row_lock_count bigint 请求的行锁的累积数量。
row_lock_wait_count bigint 在行锁上等待数据库引擎的累积次数。
row_lock_wait_in_ms bigint 行锁上等待数据库引擎的总毫秒数。
page_lock_count bigint 请求的页锁的累积数量。
page_lock_wait_count bigint 数据库引擎在页锁上等待的累积次数。
page_lock_wait_in_ms bigint 数据库引擎在页锁上等待的总毫秒数。
index_lock_promotion_attempt_count bigint 数据库引擎尝试升级锁的累积次数。
index_lock_promotion_count bigint 数据库引擎升级锁的累积次数。
page_latch_wait_count bigint 由于闩锁争用,数据库引擎等待的累积次数。
page_latch_wait_in_ms bigint 由于闩锁争用,数据库引擎等待的累积毫秒数。
page_io_latch_wait_count bigint 数据库引擎在 I/O 页闩锁上等待的累积次数。
page_io_latch_wait_in_ms bigint 数据库引擎在页 I/O 闩锁上等待的累积毫秒数。
tree_page_latch_wait_count bigint 仅包含上层 B 树页的page_latch_wait_count子集。 对堆或列存储索引始终为 0。
tree_page_latch_wait_in_ms bigint 仅包含高级 B 树页的page_latch_wait_in_ms集。 对堆或列存储索引始终为 0。
tree_page_io_latch_wait_count bigint 仅包含上层 B 树页的page_io_latch_wait_count集。 对堆或列存储索引始终为 0。
tree_page_io_latch_wait_in_ms bigint 仅包含上层 B 树页的page_io_latch_wait_in_ms集。 对堆或列存储索引始终为 0。
page_compression_attempt_count bigint 对于表、索引或索引视图的特定分区,针对 PAGE 级压缩计算的页数。 因为未能极大地节省空间,所以将包括未压缩的页。 对于列存储索引,始终为 0。
page_compression_success_count bigint 对于表、索引或索引视图的特定分区,使用 PAGE 压缩功能压缩的数据页数。 对于列存储索引,始终为 0。

注意

文档在提到索引时一般使用 B 树这个术语。 在行存储索引中,数据库引擎实现了 B+ 树。 这不适用于列存储索引或内存优化表上的索引。 有关详细信息,请参阅 SQL Server 以及 Azure SQL 索引体系结构和设计指南

注解

此动态管理对象不接受 CROSS APPLY 来自和 OUTER APPLY.

可以使用 sys.dm_db_index_operational_stats 跟踪用户必须等待读取或写入表、索引或分区的时间长度,并确定遇到重大 I/O 活动或热点的表或索引。

使用以下各列可标识争用区。

若要分析表或索引分区的常见访问模式,请使用以下列:

  • leaf_insert_count

  • leaf_delete_count

  • leaf_update_count

  • leaf_ghost_count

  • range_scan_count

  • singleton_lookup_count

若要标识闩锁和锁争用,请使用这些列:

  • page_latch_wait_countpage_latch_wait_in_ms

    这些列指示索引或堆上是否存在闩锁争用以及争用的意义。

  • row_lock_countpage_lock_count

    这些列指示数据库引擎尝试获取行锁和页锁的次数。

  • row_lock_wait_in_ms和page_lock_wait_in_ms

    这些列指示索引或堆上是否存在锁争用以及争用的意义。

分析索引或堆分区上物理 I/O 的统计信息

  • page_io_latch_wait_countpage_io_latch_wait_in_ms

    这些列指示是否已发出物理 I/O 以便将索引或堆页载入内存以及发出的 I/O 数。

列备注

lob_orphan_create_countlob_orphan_insert_count中的值应始终相等。

对于包含一个或多个 LOB 列的非聚集索引,lob_fetch_in_pageslob_fetch_in_bytes中的值可以大于零。 有关详细信息,请参阅 Create Indexes with Included Columns。 同样,如果索引包含可推送非行列的列,则列row_overflow_fetch_in_pagesrow_overflow_fetch_in_bytes中的值可能大于 0。

如何重置元数据缓存中的计数器

只要表示堆或索引的元数据缓存对象可用,sys.dm_db_index_operational_stats返回的数据就存在。 此数据既不是持久性数据,也不是事务上一致的数据。 这意味着,不能使用这些计数器确定是否已使用索引,或确定上次使用索引的时间。 有关此内容的信息,请参阅sys.dm_db_index_usage_stats(Transact-SQL)。

只要堆或索引的元数据被载入元数据缓存,每列中的值就会被设置为零,且在从元数据缓存中删除缓存对象前会累积统计信息。 因此,活动堆或索引可能始终在其缓存中具有其元数据,并且累积计数可能会反映自上次启动 SQL Server 实例以来的活动。 活动较少的堆或索引的元数据将在使用时移入和移出缓存。 因此,它可能有、也可能没有可用值。 删除索引将导致从内存中删除对应统计信息,且函数不再报告这些统计信息。 对索引执行的其他 DDL 操作可能导致统计信息的值被重置为零。

使用系统函数指定参数值

可以使用 Transact-SQL 函数DB_ID和OBJECT_ID来指定database_idobject_id参数的值。 但是,将无效的值传递给这些函数可能会导致意外结果。 请始终确保使用 DB_ID 或 OBJECT_ID 时返回了有效的 ID。 有关详细信息,请参阅 sys.dm_db_index_physical_stats(Transact-SQL)中的 “备注”部分。

权限

需要下列权限:

  • CONTROL 对数据库中指定对象的权限

  • VIEW DATABASE STATEVIEW DATABASE PERFORMANCE STATE (SQL Server 2022) 权限,通过使用对象通配符 @object_id = NULL 返回有关指定数据库中所有对象的信息

  • VIEW SERVER STATE VIEW SERVER PERFORMANCE STATE (SQL Server 2022) 使用数据库通配符 @database_id = NULL 返回有关所有数据库的信息的权限

VIEW DATABASE STATE授予允许返回数据库中的所有对象,而不考虑对特定对象拒绝的任何 CONTROL 权限。

拒绝 VIEW DATABASE STATE 拒绝返回数据库中的所有对象,而不考虑授予对特定对象的任何 CONTROL 权限。 此外,指定数据库通配符 @database_id=NULL 时,将省略数据库。

有关详细信息,请参阅动态管理视图和函数(Transact-SQL)。

示例

A. 返回指定表的信息

以下示例返回 AdventureWorks2022 数据库中表的所有索引和分区 Person.Address 的信息。 执行此查询至少需要对 Person.Address 表具有 CONTROL 权限。

重要

使用 Transact-SQL 函数DB_ID并OBJECT_ID返回参数值时,始终确保返回有效的 ID。 如果找不到数据库或对象的名称,例如相应名称不存在或拼写不正确,则两个函数都会返回 NULL。 sys.dm_db_index_operational_stats 函数将 NULL 解释为指定所有数据库或所有对象的通配符值。 由于这可能是无心之举,所以此部分中的示例说明了确定数据库 ID 和对象 ID 的安全方法。

DECLARE @db_id int;    
DECLARE @object_id int;    
SET @db_id = DB_ID(N'AdventureWorks2022');    
SET @object_id = OBJECT_ID(N'AdventureWorks2022.Person.Address');    
IF @db_id IS NULL     
  BEGIN;    
    PRINT N'Invalid database';    
  END;    
ELSE IF @object_id IS NULL    
  BEGIN;    
    PRINT N'Invalid object';    
  END;    
ELSE    
  BEGIN;    
    SELECT * FROM sys.dm_db_index_operational_stats(@db_id, @object_id, NULL, NULL);    
  END;    
GO    

B. 返回所有表和索引的信息

以下示例返回 SQL Server 实例中所有表和索引的信息。 执行此查询需要 VIEW SERVER STATE 权限。

SELECT * FROM sys.dm_db_index_operational_stats( NULL, NULL, NULL, NULL);    
GO        

另请参阅

动态管理视图和函数 (Transact-SQL)
索引相关的动态管理视图和函数 (Transact-SQL)
监视和优化性能
sys.dm_db_index_physical_stats (Transact-SQL)
sys.dm_db_index_usage_stats (Transact-SQL)
sys.dm_os_latch_stats (Transact-SQL)
sys.dm_db_partition_stats (Transact-SQL)
sys.allocation_units (Transact-SQL)
sys.indexes (Transact-SQL)