我想测量一个插入语句的执行时间(使用我猜 SQL Server Profiler 的持续时间),该语句上有一个而不是插入触发器。如何测量这条语句的完整时间,包括触发时间?
1 回答
您在 SQL Server Profiler 中看到的查询执行时间(持续时间)是执行该查询所花费的时间,包括评估任何触发器或其他约束。
因为触发器旨在用作检查数据完整性的替代方法,所以在任何触发器也完成之前,不会认为 SQL 语句已完成。
更新:一些常用的 SQL Server 探查器事件概述:
SQL:BatchCompleted在 SQL 服务器批处理(一组语句)已完成执行时发生 - 持续时间是执行批处理的总时间。
SQL:StmtCompleted当作为批处理的一部分执行的 SQL 语句完成执行时发生 - 持续时间再次是执行该单个语句的时间。
SP:Completed当存储过程完成执行时发生 - 显示的持续时间是完成存储过程执行的时间。
SP:StmtCompleted在作为存储过程的一部分执行的 SQL 语句完成时发生。
批处理是由语句分隔的一组 SQL 语句GO
,但是要理解上述内容,您还应该知道所有 SQL 服务器命令都是在批处理的上下文中执行的*。
此外,上述每个事件也都有相应的Starting
事件 - SP:Starting
、SQL:BatchStarting
和。这些没有列出持续时间(因为我们还不知道持续时间,因为它尚未完成,但是确实有助于显示持续时间记录的开始时间)。SQL:StmtStarting
SP:StmtCompleted
为了更好地理解这些事件之间的关系,我建议您尝试捕获一些简单示例的一些痕迹(来自 SQL Server Management Studio),例如:
SELECT * FROM SomeTable
GO
SELECT * FROM SomeTable
SELECT * FROM OtherTable
GO
SELECT * FROM SomeTable
exec SomeProc
GO
正如您应该看到的,对于上面的 3 个示例中的每一个,您总是得到一个SQL:BatchStarting
and SQL:BatchCompleted
,但是其他事件类型提供了有关各个命令运行的更多详细信息。
出于这个原因,我通常最倾向于使用SQL:BatchCompleted
事件,但是如果您尝试测量的语句作为较大批处理的一部分(或在存储过程中)执行,那么您可能会发现其他事件类之一很有帮助。
有关各种 SQL Server 分析事件的更多信息,请参阅TSQL 事件类别 (MSDN) - 有很多!
最后,如果您在 SQL Server Management Studio 中执行此命令,请注意记录执行时间的最简单方法是使用客户端统计功能:
(*) 我很确定一切都是作为批次的一部分执行的,尽管我没有设法在互联网上找到任何证据来证实这一点。