首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >执行过程的次数

执行过程的次数
EN

Stack Overflow用户
提问于 2015-02-07 18:39:41
回答 3查看 2.4K关注 0票数 0

要求:

要计算过程执行的次数,请执行

据我所知,到目前为止,sys.dm_exec_procedure_stats可以用于近似计数,但这只是在最后一次重新启动服务之后。我发现这个link on this website是相关的,但是我需要精确的计数,这不应该在服务重新启动之后被清除掉。

能给我一些关于这个的建议吗?

Hack:我需要跟踪的过程有一个select语句,因此返回一些存储在称为Results的永久表中的行。我能想到的最简单的解决方案是在Results表中创建一个列,以跟踪过程执行情况,在插入之前从该列中选择最大值,并向其中添加一个以增加计数。这个解决方案对我来说似乎也很愚蠢,但我能想到的最好的办法。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2015-02-07 19:08:39

我认为您可以创建一个序列对象,假设您使用的是Server 2012或更高版本。

代码语言:javascript
复制
CREATE SEQUENCE ProcXXXCounter
    AS int
    START WITH 1
    INCREMENT BY 1 ;

然后在过程中从它获取一个值:

代码语言:javascript
复制
declare @CallCount int

select @CallCount = NEXT VALUE FOR ProcXXXCounter

当然,这样做有很小的开销,但是不会导致类似的阻塞问题,因为序列是在事务外处理的,所以使用表可能会发生类似的阻塞问题。

序列参数:https://msdn.microsoft.com/en-us/library/ff878091.aspx

票数 2
EN

Stack Overflow用户

发布于 2015-02-07 19:06:14

我唯一能想到的跟踪执行次数的方法,即使服务已经重新启动,就是在数据库中有一个表,每次执行时都在过程中插入一个行到该表。

也可以添加一个datetime列来收集有关执行的更多信息。以及为执行等的用户提供的列。

票数 1
EN

Stack Overflow用户

发布于 2015-02-07 19:35:11

这可以通过使用扩展事件轻松地完成,而且不需要企业版。sqlserver.module_end事件将触发、正确设置谓词并使用直方图目标。

http://sqlperformance.com/2014/06/extended-events/predicate-order-matters https://technet.microsoft.com/en-us/library/ff878023(v=sql.110).aspx

若要使用该值,请查询直方图目标(在评审目标输出示例下)。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28385900

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档