您的位置:首页 > 数据库

SQL Server: 对T-SQL语句进行性能分析

2014-02-24 12:17 369 查看

清除SQL Server的数据和过程缓冲区

在对SQL语句进行性能分析前,首先要执行以下命令(但禁止在在线服务器上执行此命令!)以清除SQL Server的数据和过程缓冲区:

DBCC DROPCLEANBUFFERS;
DBCC FREEPROCCACHE;

GO


Notes:

这两条命令的作用是清除SQL Server的数据和过程缓冲区,使得我们进行性能分析时,每次执行的查询都在同一起点上。如果不这么做,对查询所得到的执行时间和I/O消耗就不具有可比性了。
执行这两条命令需要sysadmin权限。You have to be an member of the sysadmin role to issue these 2 commands.
禁止在生产环境的服务器上执行此命令!原因,正如 Notes[1] 对它的作用的解释。

用SET STATISTICS IO和SET STATISTICS TIME进行性能分析

在SQL Server Management Studio里执行:
SET STATISTICS PROFILE OFF;
SET STATISTICS IO ON;
SET STATISTICS TIME ON;

GO

-- // The SQL statement to analysis

GO


会得到以下这样的统计结果:

(8653 row(s) affected)
Table '...'. Scan count 1, logical reads 160, physical reads 4, read-ahead reads 158, lob logical reads 0, lob physical reads 0, lob read-ahead reads 0.

SQL Server Execution Times:
CPU time = 16 ms,  elapsed time = 91 ms.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: