SQL Server Profiler

时间:2011-08-29 19:18:48

标签: sql sql-server

使用SQL Server探查器时 持续时间和CPU有什么区别? 我知道默认情况下两者都显示为MilliSeconds,CPU是运行查询所花费的CPU时间量,而持续时间更像是查询返回任何数据所花费的时间。

根据我的理解,如果有任何阻塞等,您的CPU时间可能会更短,但持续时间可能更长。

任何人都可以提供更多洞察力吗?争夺BOL但很难找到微妙的差异。

2 个答案:

答案 0 :(得分:8)

CPU时间表示所有CPU 上请求/语句(取决于您正在监视的事件)主动(未暂停)消耗的时间。对于单线程查询,这将始终小于或等于经过的时间(持续时间=挂钟时间)。但对于并行查询,CPU时间超过经过的时间,因为它会累计来自多个CPU的CPU时间。

通常,经过时间和CPU时间之间的区别适用于SQL Server中的任何位置,从SET STATISTICS TIME ON输出到sys.dm_exec_query_stats等DMV(其中CPU时间称为worker_time)或{{3 (在此DMV中再次命名为cpu_time)。

答案 1 :(得分:3)

持续时间可以包括等待时间,I / O,数据传输时间等.CPU 只是 CPU花费的时间。如果您的查询受CPU约束,那么它将比I / O或内存限制更接近。