sys.dm_exec_query_stats

更新日期: 2006 年 12 月 12 日

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

ms189741.note(zh-cn,SQL.90).gif注意:
如果服务器中当前正在执行工作负荷,则 sys.dm_exec_query_stats 的初始查询可能会生成不准确的结果。可以通过重新运行查询来确定更准确的结果。
列名 数据类型 说明

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 开头)。值 -1 指示批查询的结尾处。

plan_generation_num

bigint

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

plan_handle

varbinary(64)

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

creation_time

datetime

编译计划的时间。

last_execution_time

datetime

上次执行计划的时间。

execution_count

bigint

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

total_worker_time

bigint

此计划自编译以来执行所用的 CPU 时间总量(微秒)。

last_worker_time

bigint

上次执行计划所用的 CPU 时间(微秒)。

min_worker_time

bigint

此计划在单次执行期间曾占用的最小 CPU 时间(微秒)。

max_worker_time

bigint

此计划在单次执行期间曾占用的最大 CPU 时间(微秒)。

total_physical_reads

bigint

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

last_physical_reads

bigint

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

min_physical_reads

bigint

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

max_physical_reads

bigint

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

total_logical_writes

bigint

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

last_logical_writes

bigint

上次执行计划时所执行的逻辑写入次数。

min_logical_writes

bigint

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

max_logical_writes

bigint

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

total_logical_reads

bigint

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

last_logical_reads

bigint

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

min_logical_reads

bigint

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

max_logical_reads

bigint

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

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

任意一次完成此计划的执行所占用的最长时间(微秒)。

权限

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

备注

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

示例

以下示例按平均 CLR 时间返回有关前五个查询的信息。

SELECT TOP 5 creation_time, last_execution_time, total_clr_time,
    total_clr_time/execution_count AS [Avg CLR Time], last_clr_time,
    execution_count, 
    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
ORDER BY total_clr_time/execution_count DESC;
GO

请参阅

参考

动态管理视图和函数
与执行有关的动态管理视图和函数
sys.dm_exec_sql_text
sys.dm_exec_query_plan

帮助和信息

获取 SQL Server 2005 帮助

更改历史记录

发布日期 历史记录

2006 年 12 月 12 日

更改的内容:
  • 更正了 sql_handleplan_generation_numplan_handle 列的定义。

2006 年 4 月 14 日

更改的内容:
  • 更正了语法。

2005 年 12 月 5 日

新增内容:
  • 添加了如果服务器中当前正在执行工作负荷时,则需要多次查询此动态管理视图才能获取更准确结果的有关说明。
  • 说明了 statement_end_offsetstatement_start_offset 列是以零为基的,statement_end_offset 列中的值 -1 指示批处理结束。