1

我想创建 SQL 单元测试来测量我的存储过程的执行时间。有没有办法断言每次执行的持续时间?

我最终使用的解决方案:

--运行我的存储过程

exec mySP

--获取指标

  SELECT d.object_id, d.database_id, OBJECT_NAME(object_id, database_id) 'proc name',   
    d.cached_time, d.last_execution_time, d.total_elapsed_time,  
    d.total_elapsed_time/d.execution_count AS [avg_elapsed_time],  
    d.last_elapsed_time, d.execution_count  
FROM sys.dm_exec_procedure_stats AS d  
where OBJECT_NAME(object_id, database_id) = 'mySP'
ORDER BY [total_worker_time] DESC;  

--朗姆我的断言基于last_elapsed_timeavg_elapsed_time

4

1 回答 1

0

您可以查看sys.dm_exec_procedure_statsSQLServer 2008 中的可用信息。此 DMV 提供了一些有用的信息,例如

在此处输入图像描述

您也可以查看 SET STATISTICS TIME ON

set statistics time on
exec usp_test
set statistics time off

您可以在消息选项卡中查看时间,如下所示

SQL Server Execution Times:
   CPU time = 171 ms,  elapsed time = 5060 ms.
于 2016-10-13T09:22:06.460 回答