三种调优查询的主要的方法
上一篇 /
下一篇 2008-11-10 18:05:35
/ 个人分类:数据库
1、使用SET STATISTICS IO 检查查询所产生的读和写
2、使用SET STATISTICS TIME检查查询的运行时间
3、使用SET SHOWPLAN 分析查询的查询计划
SET STATISTICS IO
命令SET STATISTICS IO ON 强制SQL Server 报告执行事务时I/O的实际活动。它不能与SET NOEXEC ON 选项配对使用,因为它仅仅对监测实际执行命令的I/O活动有意义。一旦这个选项被打开,每个查询产生包括I/O统计信息的额外输出。为了关闭这个选项,执行SET STATISTICS IO OFF.
注:这些命令也能在 Sybase Adaptive Server中运行,虽然结果集可能看起来有点不同
扫描统计告诉我们扫描执行的数量,逻辑读显示的是从缓存中读出来的页面的数量,物理读显示的是从磁盘中读的页面的数量,Read-ahead 读显示了放置在缓存中用于将来读操作的页面数量。
输出项 含义
Table
表的名称。
Scan count (扫描计数)
执行的索引或表扫描数。
logical reads (逻辑读取)
从数据缓存读取的页数。
physical reads (物理读取)
从磁盘读取的页数。
read-ahead reads (预读)
为进行查询而放入缓存的页数。
lob logical reads (lob 逻辑读取)
从数据缓存读取的 text、ntext、image 或大值类型 (varchar(max)、nvarchar(max)、varbinary(max)) 页的数目。
lob physical reads(lob 物理读取)
从磁盘读取的 text、ntext、image 或大值类型页的数目。
lob read-ahead reads (lob 预读)
为进行查询而放入缓存的 text、ntext、image 或大值类型页的数目。
SET STATISTICS TIME
一个事务的实耗时间是一个不稳定的测量,因为这些时间与在服务器上其他用户的活动有关。然而,相比那些对你的用户没有任何意义的数据页数字,它提供了一些实际的测量。他们关心等待查询返回的时间消耗,不关心数据的缓存和有效的read-ahead。SET STATISTICS TIME ON命令报告下面的查询的实际占用时间和CPU使用情况。执行SET STATISTICS TIME OFF禁止这个选项。
注意实耗时间和CPU时间是以毫秒显示。这个数字在你的电脑上可能会改变(但是不要尝试与我们的笔记本电脑比较你机器的性能,因为这不是代表性的指标)。而且,每次你执行这个脚本,考虑到你的SQL Server还在处理一些其他事务,你得到的统计信息都可能有一点不同。
SHOWPLAN 输出和分析
SET SHOWPLAN_TEXT { ON | OFF }
默认情况下,SHOWPLAN_TEXT ON使得你正在审查的代码不被执行。而是,SQL Server 编译这些代码并且显示这个查询的执行计划。直到你发出SET.SHOWPLAN_TEXT OFF命令后它才停止。
◆SET NOEXEC{ ON | OFF}: 检查你的Transact-SQL代码的语法,包括编译该代码但不执行。当使用延迟名字解析时,这对检查一个查询语句的语法是很有用的。即,当一个表还没有创建时,你就可以检查基于该表的查询语句的语法。
◆SET FMTONLY{ ON | OFF }:仅向客户端返回查询的元数据。对于SELECT语句,通常仅返回列头。
◆SET PARSEONLY { ON | OFF }:检查你的Transact-SQL代码的语法,但不编译或执行该代码。
相关阅读:
- PLSQL导入导出数据库 (ljhappy1, 2008-11-04)
- sql中的表连接 (chenjie021, 2008-11-04)
- Oracle常见错误及处理办法(整理) (Jon, 2008-11-05)
- 索引分析和优化 (chenjie021, 2008-11-05)
- 查询锁的表含义(sp_lock) (chenjie021, 2008-11-05)
- oracle之SQL学习笔记 (Jon, 2008-11-05)
- SQL中的N (chenjie021, 2008-11-07)
- SQL中的聚集索引和非聚集索引的区别 (chenjie021, 2008-11-07)
- SQL提高速度注意事项 (chenjie021, 2008-11-10)
- SQL 中having (chenjie021, 2008-11-10)
收藏
举报
TAG:
数据库