sys.dm_exec_query_stats (Transact-SQL)

 

返回 SQL Server 中缓存查询计划的聚合性能统计信息。 缓存计划中的每个查询语句在该视图中对应一行,并且行的生存期与计划本身相关联。 在从缓存删除计划时,也将从该视图中删除对应行。

备注

如果服务器中当前正在执行工作负荷,则 sys.dm_exec_query_stats 的初始查询可能会生成不准确的结果。 可以通过重新运行查询来确定更准确的结果。

适用范围:SQL Server(SQL Server 2008 到当前版本) Azure SQL Database。

列名

数据类型

说明

sql_handle

varbinary(64)

表示包含查询的批查询或存储过程的标记。

通过调用 sys.dm_exec_sql_text 动态管理函数,sql_handle 可以和 statement_start_offsetstatement_end_offset 一起用于检索查询的 SQL 文本。

statement_start_offset

int

指示行所说明的查询在其批查询或持久化对象文本中的开始位置(以字节为单位,从 0 开始)。

statement_end_offset

int

指示行所说明的查询在其批查询或持久化对象文本中的结束位置(以字节为单位,从 0 开始)。 对于 SQL Server 2014 之前的版本,值 -1 指示批查询的末尾。 不再包含尾随的注释。

plan_generation_num

bigint

可用于在重新编译后区分不同计划实例的序列号。

plan_handle

varbinary(64)

表示查询所属的已编译计划的标记。 可以将此值传递给 sys.dm_exec_query_plan 动态管理函数来获取查询计划。

当本机编译的存储过程查询内存优化的表时,此项将始终为 0x000。

creation_time

datetime

编译计划的时间。

last_execution_time

datetime

上次开始执行计划的时间。

execution_count

bigint

计划自上次编译以来所执行的次数。

total_worker_time

bigint

此计划自编译以来执行所用的 CPU 时间总量(以微秒为单位报告,但仅精确到毫秒)。

对于本机编译的存储过程,如果许多执行所用的时间都不到 1 毫秒,则 total_worker_time 可能不精确。

last_worker_time

bigint

上次执行计划所用的 CPU 时间(以微秒为单位报告,但仅精确到毫秒)。1

min_worker_time

bigint

此计划在单次执行期间所用的最小 CPU 时间(以微秒为单位报告,但仅精确到毫秒)。1

max_worker_time

bigint

此计划在单次执行期间所用的最大 CPU 时间(以微秒为单位报告,但仅精确到毫秒)。1

total_physical_reads

bigint

此计划自编译后在执行期间所执行的物理读取总次数。

当查询内存优化的表时,此项将始终为 0。

last_physical_reads

bigint

上次执行计划时所执行的物理读取次数。

当查询内存优化的表时,此项将始终为 0。

min_physical_reads

bigint

此计划在单个执行期间所执行的最少物理读取次数。

当查询内存优化的表时,此项将始终为 0。

max_physical_reads

bigint

此计划在单个执行期间所执行的最多物理读取次数。

当查询内存优化的表时,此项将始终为 0。

total_logical_writes

bigint

此计划自编译后在执行期间所执行的逻辑写入总次数。

当查询内存优化的表时,此项将始终为 0。

last_logical_writes

bigint

上次执行计划时变脏的缓冲池页数。 如果页已变脏(已修改),则不计入写次数。

当查询内存优化的表时,此项将始终为 0。

min_logical_writes

bigint

此计划在单个执行期间所执行的最少逻辑写入次数。

当查询内存优化的表时,此项将始终为 0。

max_logical_writes

bigint

此计划在单个执行期间所执行的最多逻辑写入次数。

当查询内存优化的表时,此项将始终为 0。

total_logical_reads

bigint

此计划自编译后在执行期间所执行的逻辑读取总次数。

当查询内存优化的表时,此项将始终为 0。

last_logical_reads

bigint

上次执行计划时所执行的逻辑读取次数。

当查询内存优化的表时,此项将始终为 0。

min_logical_reads

bigint

此计划在单个执行期间所执行的最少逻辑读取次数。

当查询内存优化的表时,此项将始终为 0。

max_logical_reads

bigint

此计划在单个执行期间所执行的最多逻辑读取次数。

当查询内存优化的表时,此项将始终为 0。

total_clr_time

bigint

编译计划后,因执行此计划而在 Microsoft.NET Framework 公共语言运行时 (CLR) 对象内使用的时间(以微秒为单位报告,但仅精确到毫秒)。 CLR 对象可以是存储过程、函数、触发器、类型和聚合。

last_clr_time

bigint

在上一次执行此计划期间,在 .NET Framework 公共语言运行时 (CLR) 对象内执行所用的时间(以微秒为单位报告,但仅精确到毫秒)。 CLR 对象可以是存储过程、函数、触发器、类型和聚合。

min_clr_time

bigint

此计划在单次执行期间在 .NET Framework CLR 对象内所用的最小时间(以微秒为单位报告,但仅精确到毫秒)。 CLR 对象可以是存储过程、函数、触发器、类型和聚合。

max_clr_time

bigint

此计划在单次执行期间在 .NET Framework CLR 内所用的最大时间(以微秒为单位报告,但仅精确到毫秒)。 CLR 对象可以是存储过程、函数、触发器、类型和聚合。

total_elapsed_time

bigint

上次完成执行此计划所用的总时间(以微秒为单位报告,但仅精确到毫秒)。

last_elapsed_time

bigint

最近一次完成执行此计划所用的时间(以微秒为单位报告,但仅精确到毫秒)。

min_elapsed_time

bigint

任何一次完成执行此计划所用的最小时间(以微秒为单位报告,但仅精确到毫秒)。

max_elapsed_time

bigint

任何一次完成执行此计划所用的最大时间(以微秒为单位报告,但仅精确到毫秒)。

query_hash

Binary(8)

对查询计算的二进制哈希值,用于标识具有类似逻辑的查询。 可以使用查询哈希确定仅仅是文字值不同的查询的聚合资源使用情况。

query_plan_hash

binary(8)

对查询执行计划计算的二进制哈希值,用于标识类似的查询执行计划。 可以使用查询计划哈希查找具有类似执行计划的查询的累积成本。

当本机编译的存储过程查询内存优化的表时,此项将始终为 0x000。

total_rows

bigint

查询返回的总行数。 不能为 Null。

当本机编译的存储过程查询内存优化的表时,此项将始终为 0。

last_rows

bigint

上一次执行查询返回的行数。 不能为 Null。

当本机编译的存储过程查询内存优化的表时,此项将始终为 0。

min_rows

bigint

查询自上次编译以来已执行计划的次数所返回的最小行数。 不能为 Null。

当本机编译的存储过程查询内存优化的表时,此项将始终为 0。

max_rows

bigint

查询自上次编译以来已执行计划的次数所返回的最大行数。 不能为 Null。

当本机编译的存储过程查询内存优化的表时,此项将始终为 0。

statement_sql_handle

varbinary(64)

适用范围:SQL Server 2014 到 SQL Server 2014。

保留供将来使用。

statement_context_id

bigint

适用范围:SQL Server 2014 到 SQL Server 2014。

保留供将来使用。

1 对于启用统计信息收集时的本机编译的存储过程,以毫秒为单位收集工作线程时间。 如果查询执行不到 1 毫秒,则该值将为 0。

权限

需要针对服务器的 VIEW SERVER STATE 权限。

备注

查询完成后,将更新该视图中的统计信息。

示例

A. 查找 TOP N 查询

以下示例按平均 CPU 时间返回排名前五个的查询的相关信息。 此示例将根据查询的查询哈希对查询进行聚合,以便按照查询的累积资源消耗来分组在逻辑上等效的查询。

USE AdventureWorks2012; GO SELECT TOP 5 query_stats.query_hash AS "Query Hash", SUM(query_stats.total_worker_time) / SUM(query_stats.execution_count) AS "Avg CPU Time", MIN(query_stats.statement_text) AS "Statement Text" FROM (SELECT QS.*, SUBSTRING(ST.text, (QS.statement_start_offset/2) + 1, ((CASE statement_end_offset WHEN -1 THEN DATALENGTH(ST.text) ELSE QS.statement_end_offset END - QS.statement_start_offset)/2) + 1) AS statement_text FROM sys.dm_exec_query_stats AS QS CROSS APPLY sys.dm_exec_sql_text(QS.sql_handle) as ST) as query_stats GROUP BY query_stats.query_hash ORDER BY 2 DESC;

B. 对查询返回行计数聚合

以下示例返回查询的行计数聚合信息(总行数、最小行数、最大行数和上一次行数)。

SELECT qs.execution_count, SUBSTRING(qt.text,qs.statement_start_offset/2 +1, (CASE WHEN qs.statement_end_offset = -1 THEN LEN(CONVERT(nvarchar(max), qt.text)) * 2 ELSE qs.statement_end_offset end - qs.statement_start_offset )/2 ) AS query_text, qt.dbid, dbname= DB_NAME (qt.dbid), qt.objectid, qs.total_rows, qs.last_rows, qs.min_rows, qs.max_rows FROM sys.dm_exec_query_stats AS qs CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) AS qt WHERE qt.text like '%SELECT%' ORDER BY qs.execution_count DESC;

请参阅

动态管理视图和函数 (Transact-SQL)
与执行有关的动态管理视图和函数 (Transact-SQL)
sys.dm_exec_sql_text (Transact-SQL)
sys.dm_exec_query_plan (Transact-SQL)