SQL Server 2008通过sys.dm_exec_procedure_stats得到存储过程的执行信息的相关操作的相关知识是本文我们主要要介绍的内容,接下来我们就开始介绍这部分内容 。
很多DBA都希望能够得到某个存储过程的执行信息,比如:
1)执行了多少次 。
2)执行的执行计划如何 。
3)执行的平均读写如何 。
4)执行平均需要多少时间 。
等等 。幸运的是SQL server 2008 提供了一个这样的DMV,使得我们比较容易就得到上面的信息 。这个DMV是sys.dm_exec_procedure_stats,它输出了下面的信息(部分截图,具体的请参考联机丛书):
列名
|
数据类型
|
说明
|
database_id
|
int
|
存储过程所在的数据库 ID 。
|
object_id
|
int
|
存储过程的对象标识号 。
|
cached_time
|
datetime
|
存储过程添加到缓存的时间 。
|
cached_time
|
datetime
|
存储过程添加到缓存的时间 。
|
last_execution_time
|
datetime
|
上次执行存储过程的时间 。
|
execution_count
|
bigint
|
存储过程自上次编译以来所执行的次数 。
|
total_worker_time
|
bigint
|
此存储过程自编译以来执行所用的 CPU 时间总量(微秒) 。
|
last_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
|
上次执行存储过程时所执行的逻辑读取次数 。
|
total_elapsed_time
|
bigint
|
完成此存储过程的执行所用的总时间(微秒) 。
|
last_elapsed_time
|
bigint
|
最近完成此存储过程的执行所用的时间(微秒) 。
|
可以通过下面的语句,得到按照执行时间排序的前10 的存储过程的执行信息:
- SELECT TOP 10 a.object_id, a.database_id, OBJECT_NAME(object_id, database_id) proc name,
- a.cached_time, a.last_execution_time, a.total_elapsed_time, a.total_elapsed_time/a.execution_count AS [avg_elapsed_time],
- a.execution_count,
- a.total_physical_reads/a.execution_count avg_physical_reads,
- a.total_logical_writes,
- a.total_logical_writes/ a.execution_count avg_logical_reads,
- a.last_elapsed_time,
- a.total_elapsed_time / a.execution_count avg_elapsed_time,
- b.text,c.query_plan
- FROM sys.dm_exec_procedure_stats AS a
- CROSS APPLY sys.dm_exec_sql_text(a.sql_handle) b
- CROSS APPLY sys.dm_exec_query_plan(a.plan_handle) c
- ORDER BY [total_worker_time] DESC;
- GO
以上就是SQL Server 2008通过sys.dm_exec_procedure_stats得到存储过程的执行信息的相关操作的全部内容,本文我们主要就介绍到这里了,希望本次的介绍能够对您有所帮助 。