SQL Server 数据库存储过程缓存表sys.dm_exec_procedure_stats的具体作用

关于数据库存储过程
看到很多文章提出可以通过表sys.exec_procedure_stat来查询数据库存储过程
执行了多少次、执行的执行计划如何、执行的平均读写如何、执行平均需要多少时间等信息。
具体代码如:

SELECT a.name                AS 存储过程名称,
       a.create_date         AS 创建日期,
       a.modify_date         AS 修改日期,
       b.cached_time         AS 缓存时间,
       b.last_execution_time AS 最后执行日期,
       b.execution_count     AS 执行次数
FROM sys.procedures a
       LEFT JOIN sys.dm_exec_procedure_stats b ON a.object_id = b.object_id AND b.database_id = '11'
WHERE a.is_ms_shipped = 0
ORDER BY b.execution_count desc

但它的查询结果里有很多我很确信执行了的存储过程完全没有执行记录。

想请大佬指导一下这个表sys.exec_procedure_stat到底什么时候发挥作用?什么情况下能更新这个表?什么情况无法更新?
如何能在数据库中记录存储过程执行情况?

感激不尽

sql

1个回答

qq_38707936
qq_38707936 回复qq_38707936:“重点是不太理解这种情况” ,多打了个不,不会删除,尴尬
10 个月之前 回复
qq_38707936
qq_38707936 大佬这个帖子我看过了。不过我的问题重点在后面 用了帖子里查询结果也有很多我很确信执行了的存储过程完全没有执行记录。重点不是不太理解这种情况。想知道什么时候存储过程才能在再这个表中留有缓存记录。而我的一些存储过程为什么执行了也没有留下记录。大佬知道的话希望能解惑一下,感谢
10 个月之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问
相关内容推荐