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

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


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

DBCC DROPCLEANBUFFERS;
DBCC FREEPROCCACHE;

GO

Notes:

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


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值