microsoft的优化sql方法--

microsoft的优化sql方法--

ID:22371545

大小:62.50 KB

页数:8页

时间:2018-10-28

microsoft的优化sql方法--_第1页
microsoft的优化sql方法--_第2页
microsoft的优化sql方法--_第3页
microsoft的优化sql方法--_第4页
microsoft的优化sql方法--_第5页
资源描述:

《microsoft的优化sql方法--》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、Microsoft的优化SQL方法>>  本文是SQLServerSQL语句优化系列文章的第一篇。该系列文章描述了在MicosoftsSQLServer2000关系数据库管理系统中优化SELECT语句的基本技巧,我们讨论的技巧可在Microsoft'sSQLEnterpriseManager或MicrosoftSQLQueryAnalyzer(查询分析器)提供的Microsoft图形用户界面使用。  除调优方法外,我们给你展示了最佳实践,你可应用到你的SQL语句中以提高性能(所有的例子和语法都已在MicrosoftSQLServer2000中验证)。  阅

2、读该系列文章后,你应该对Microsoft工具包中提供的查询优化工具和技巧有一个基本的了解,我们将提供包含各种各样的以提高性能和加速数据读取操作的查询技巧。  Microsoft提供了三种调优查询的主要的方法:   1、使用SETSTATISTICSIO检查查询所产生的读和写  2、使用SETSTATISTICSTIME检查查询的运行时间  3、使用SETSHOemployeesGOSETSTATISTICSIOOFFGOResults:---------------2977TableEmployees.Scancount1,logicalread53,physi

3、calreads0,readaheadreads0.  这个扫描统计告诉我们扫描执行的数量,逻辑读显示的是从缓存中读出来的页面的数量,物理读显示的是从磁盘中读的页面的数量,Read-ahead读显示了放置在缓存中用于将来读操作的页面数量。  此外,我们执行一个系统存储过程获得表大小的统计信息以供我们分析:sp_spaceusedemployeesResults:nameroployees29772008KB1504KB448KB56KB  通过看这些信息我们能得到些什么呢?  ◆这个查询没有扫描整个表,在表中的数据量超过1.5M字节,而仅仅执行了53个逻辑I/O操

4、作就得到了结果。这表明该查询发现了一个可用来计算结果的索引,并且扫描索引比扫描所有数据页花费更少的I/O操作。  ◆索引页几乎全部放在数据缓存中,所以物理读的值是零。这是因为我们之前不久是在employees表上执行了其他查询,此时表和它的索引已经被缓存。你的查询开销可能有不同。  ◆Microsoft报告没有read-ahead(预读)活动。在这种情况下,数据和索引页已经被缓存起来了。当对一个很大的表作表扫描时,read-ahead可能会半路插入进来,并且在你的查询用到它们之前缓存起所需的页。当SQLServer确定你的事务是顺序读取数据库页并且认为它能预测到你

5、下一步将用到的页面时,Real-ahead会自动打开。实际上一个独立的SQLServer连接在你的进程之前已开始运行并为它缓存数据页。(配置和优化read-ahead参数已超出这篇文章的讨论范围。  在这个例子中,该查询已经尽可能有效率地执行了,不必进一步优化。  SETSTATISTICSTIME  一个事务的实耗时间是一个不稳定的测量,因为这些时间与在服务器上其他用户的活动有关。然而,相比那些对你的用户没有任何意义的数据页数字,它提供了一些实际的测量。他们关心等待查询返回的时间消耗,不关心数据的缓存和有效的read-ahead。SETSTATISTICSTIM

6、EON命令报告下面的查询的实际占用时间和CPU使用情况。执行SETSTATISTICSTIMEOFF禁止这个选项。SETSTATISTICSTIMEONGOSELECTCOUNT(*)FROMtitleauthersGOSETSTATISTICSTIMEOFFGOResults:SQLServerExecutionTimes;Cuptime=0ms. Elapsedtime=8672ms.SQLServerParseandpileTime:Cputime=10ms----------------25(1roes:Cputime=0ms.?Elapsedtime=1

7、0ms.SQLServerParseandpileTime:Cuptime=0ms  第一条信息报告了多少使人困惑的占用(实耗)时间,8672豪秒,这个数据与我们的脚本不相关,这显示的是之前一个命令执行以来逝去的时间。你可以忽略这条信息。SQLServer仅仅花费10毫秒时间去分析和编译该查询。花费0毫秒去执行它(在查询结果可看到)。其真实的意思是这个查询所花费的时间太短以至不能计量。最后的信息报告了这个SETSTATISTICSTIMEOFF123下一页>>>>这篇文章来自..,。命令相关的分析及编译花费了0毫秒。你可以忽略这个信息。最重要的信息以加重字体突出显

8、示。  注

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。