2

我想测量一个插入语句的执行时间(使用我猜 SQL Server Profiler 的持续时间),该语句上有一个而不是插入触发器。如何测量这条语句的完整时间,包括触发时间?

4

1 回答 1

6

您在 SQL Server Profiler 中看到的查询执行时间(持续时间)是执行该查询所花费的时间,包括评估任何触发器或其他约束

因为触发器旨在用作检查数据完整性的替代方法,所以在任何触发器也完成之前,不会认为 SQL 语句已完成。

更新:一些常用的 SQL Server 探查器事件概述:

  • SQL:BatchCompleted在 SQL 服务器批处理(一组语句)已完成执行时发生 - 持续时间是执行批处理的总时间。

  • SQL:StmtCompleted当作为批处理的一部分执行的 SQL 语句完成执行时发生 - 持续时间再次是执行该单个语句的时间。

  • SP:Completed当存储过程完成执行时发生 - 显示的持续时间是完成存储过程执行的时间。

  • SP:StmtCompleted在作为存储过程的一部分执行的 SQL 语句完成时发生。

批处理是由语句分隔的一组 SQL 语句GO,但是要理解上述内容,您还应该知道所有 SQL 服务器命令都是在批处理的上下文中执行的*。

此外,上述每个事件也都有相应的Starting事件 - SP:StartingSQL:BatchStarting和。这些没有列出持续时间(因为我们还不知道持续时间,因为它尚未完成,但是确实有助于显示持续时间记录的开始时间)。SQL:StmtStartingSP:StmtCompleted

为了更好地理解这些事件之间的关系,我建议您尝试捕获一些简单示例的一些痕迹(来自 SQL Server Management Studio),例如:

SELECT * FROM SomeTable
GO

SELECT * FROM SomeTable
SELECT * FROM OtherTable
GO

SELECT * FROM SomeTable
exec SomeProc
GO

正如您应该看到的,对于上面的 3 个示例中的每一个,您总是得到一个SQL:BatchStartingand SQL:BatchCompleted,但是其他事件类型提供了有关各个命令运行的更多详细信息。

出于这个原因,我通常最倾向于使用SQL:BatchCompleted事件,但是如果您尝试测量的语句作为较大批处理的一部分(或在存储过程中)执行,那么您可能会发现其他事件类之一很有帮助。

有关各种 SQL Server 分析事件的更多信息,请参阅TSQL 事件类别 (MSDN) - 有很多!

最后,如果您在 SQL Server Management Studio 中执行此命令,请注意记录执行时间的最简单方法是使用客户端统计功能:

替代文字

(*) 我很确定一切都是作为批次的一部分执行的,尽管我没有设法在互联网上找到任何证据来证实这一点。

于 2010-12-09T01:44:12.353 回答