zoukankan      html  css  js  c++  java
  • SQL server 2008里面通过sys.dm_exec_procedure_stats得到存储过程的执行信息--转

    --转自:http://blogs.msdn.com/b/apgcdsd/archive/2011/05/13/sql-server-2008-sys-dm-exec-procedure-stats.aspx

    很多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
  • 相关阅读:
    js,JavaScript,a标签onclick传递参数不对,A标签调用js函数写法总结
    Java两大测试方法Junit和TestNG的比较
    java简单的测试方法执行了多少时间
    利用Chrome的Performance工具排查页面性能问题(原叫timeline)
    P3317 [SDOI2014]重建(Matrix-tree+期望)
    P2221 [HAOI2012]高速公路(线段树)
    P2473 [SCOI2008]奖励关(期望)
    P3302 [SDOI2013]森林(主席树+启发式合并)
    bzoj3932 / P3168 [CQOI2015]任务查询系统(主席树+差分)
    P2219 [HAOI2007]修筑绿化带(单调队列)
  • 原文地址:https://www.cnblogs.com/davidhou/p/5121745.html
Copyright © 2011-2022 走看看