要求:
要计算过程执行的次数,请执行
据我所知,到目前为止,sys.dm_exec_procedure_stats可以用于近似计数,但这只是在最后一次重新启动服务之后。我发现这个link on this website是相关的,但是我需要精确的计数,这不应该在服务重新启动之后被清除掉。
能给我一些关于这个的建议吗?
Hack:我需要跟踪的过程有一个select语句,因此返回一些存储在称为Results的永久表中的行。我能想到的最简单的解决方案是在Results表中创建一个列,以跟踪过程执行情况,在插入之前从该列中选择最大值,并向其中添加一个以增加计数。这个解决方案对我来说似乎也很愚蠢,但我能想到的最好的办法。
发布于 2015-02-07 19:08:39
我认为您可以创建一个序列对象,假设您使用的是Server 2012或更高版本。
CREATE SEQUENCE ProcXXXCounter
AS int
START WITH 1
INCREMENT BY 1 ;然后在过程中从它获取一个值:
declare @CallCount int
select @CallCount = NEXT VALUE FOR ProcXXXCounter当然,这样做有很小的开销,但是不会导致类似的阻塞问题,因为序列是在事务外处理的,所以使用表可能会发生类似的阻塞问题。
发布于 2015-02-07 19:06:14
我唯一能想到的跟踪执行次数的方法,即使服务已经重新启动,就是在数据库中有一个表,每次执行时都在过程中插入一个行到该表。
也可以添加一个datetime列来收集有关执行的更多信息。以及为执行等的用户提供的列。
发布于 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
若要使用该值,请查询直方图目标(在评审目标输出示例下)。
https://stackoverflow.com/questions/28385900
复制相似问题