通过sys.dm_exec_procedure_stats得到存储过程的执行信息

数据库 SQL Server
本文我们主要就介绍了SQL Server 2008通过sys.dm_exec_procedure_stats得到存储过程的执行信息的相关操作及其详细的代码实现,希望能够对您有所帮助。

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 的存储过程的执行信息:

  1. SELECT TOP 10 a.object_id, a.database_id, OBJECT_NAME(object_id, database_id) 'proc name',  
  2. a.cached_time, a.last_execution_time, a.total_elapsed_time, a.total_elapsed_time/a.execution_count AS [avg_elapsed_time],  
  3. a.execution_count,  
  4. a.total_physical_reads/a.execution_count avg_physical_reads,  
  5. a.total_logical_writes,  
  6. a.total_logical_writes/ a.execution_count  avg_logical_reads,  
  7. a.last_elapsed_time,  
  8. a.total_elapsed_time / a.execution_count   avg_elapsed_time,  
  9. b.text,c.query_plan  
  10. FROM sys.dm_exec_procedure_stats AS a  
  11. CROSS APPLY sys.dm_exec_sql_text(a.sql_handle)  b  
  12. CROSS APPLY sys.dm_exec_query_plan(a.plan_handle) c  
  13. ORDER BY [total_worker_time] DESC;  
  14. GO 

 

以上就是SQL Server 2008通过sys.dm_exec_procedure_stats得到存储过程的执行信息的相关操作的全部内容,本文我们主要就介绍到这里了,希望本次的介绍能够对您有所帮助。

【编辑推荐】

  1. SQL Server 2005导入Oracle 10g的C#源码
  2. SQL Server 2008快速清理日志文件的代码
  3. SQL Server 2008数据库中CDC的功能使用及说明
  4. SQL Server 2008阻止保存要求重新创建表的更改的问题
  5. SQL Server数据库row_number() over() 来自动产生行号
责任编辑:赵鹏 来源: MSDN
相关推荐

2011-07-08 16:07:41

Oracle job存储过程

2010-09-07 11:41:24

SQL语句

2009-09-11 15:12:26

LINQ执行存储过程

2010-11-12 09:58:34

SQL存储过程

2009-07-21 17:06:35

iBATIS.NET执

2011-07-14 13:38:34

2010-05-07 18:44:28

Oracle存储过程

2010-05-07 13:03:01

Oracle通过存储过

2010-04-29 15:58:51

Oracle存储过程

2009-08-05 08:42:41

C#中用Oracle执DataSet

2010-07-21 14:21:53

SQL Server存

2009-09-18 10:55:17

CLR存储过程

2010-07-15 12:38:14

SQL Server存

2010-09-06 11:24:32

SQL Server语句

2011-08-12 14:51:31

SQL ServerSET NOCOUNT

2010-10-22 17:14:03

SQL Server删

2010-04-16 10:11:20

Oracle存储过程

2010-04-07 13:12:25

Oracle存储过程

2010-10-29 16:22:37

SQL存储过程

2009-06-17 10:33:17

Hibernate 存
点赞
收藏

51CTO技术栈公众号