首页  ·  知识 ·  数据库
解决SQL查询性能问题
网友  IT新闻网  MS-SQL  编辑:dezai   图片来源:网络
一旦您优化了数据库索引,配备了最好的硬件和最快的磁盘,您将遇到的瓶颈是SQLServer主机的最大性能。在一定程度上,您必须关注于应用程序的优化,而不是SQLServer本身。这就要求进行最复杂的查
 一旦您优化了数据库索引,配备了最好的硬件和最快的磁盘,您将遇到的瓶颈是SQL Server主机的最大性能。在一定程度上,您必须关注于应用程序的优化,而不是SQL Server本身。这就要求进行最复杂的查询分析,确定那些(由于编写不当而造成)性能不佳的数据库查询。

SQL Server具有一个非常优秀的工具SQL Profiler,它是专门用来捕捉追踪信息的。我们可以认为它与网络数据包捕捉类似:捕捉发向SQL Server的实际原始查询,以及它们的执行时间信息。通过这些原始数据,您就能够确定一些次优查询,然后向应用程序开发人员提出改进建议。

实际的性能改进决定于应用程序本身的修改,所以对于无法修改源代码的预打包应用程序,这种方法通常是不可行的。相反,这种方法通常只适用于内部应用程序。通过这种方法,您与您的团队可以对代码进行修改,从而改进性能。

打开SQL Profiler,您首先需要创建一个新的追踪。追踪的定义是由一系列希望捕捉的事件组成的。

您通常希望捕捉远程过程调用(RPC)事件及Transact-SQL事件,因为这两种事件类型代表了向SQL Server提交或存储过程能够执行的两种查询方式。我通常在追踪中加入以下两种事件类型:

RPC:Completed。这是在RPC上执行一个存储过程后产生的,包含诸如执行时间、CPU使用率和存储过程名称等参数信息。

SP:StmtCompleted。这是在存储过程中一条语句执行完成时触发的,也包含如执行时间和CPU使用率等数据指标。

SQL:BatchCompleted。在Transact-SQL批处理结束时出现;它提供了与上面所列的RPC和存储过程示例类似的数据。

SQL:BatchStarting。在Transact-SQL批处理开始时出现,包括内部和外部存储过程。

显示计划XML。查询计划的图形化执行效果——理解查询执行方式及确定性能问题的关键。

一旦建立了追踪,它就开始捕捉数据。您肯定希望捕捉有代表性的数据,而通常这意味着需要在生产负载中执行这些追踪。一定不要捕捉您分析的主机上的文件或SQL Server表,否则分析本身会影响性能。

您需要在SQL Profiler中指定您希望查看的数据字段;我通常采用下面这个清单:

Duration

ObjectName

TextData

CPU

Reads

Writes

DatabaseName

ApplicationName

StartTime

EndTime

EventSequence

通过这些字段,我能够很好地了解每一个查找的执行时间,而且我通常只浏览那些Duration字段值特别大的数据。您将希望关注那些执行时间较长的查询,以确定是否需要改进执行时间。执行时间是以毫秒为单位的(虽然它实际存储的是微秒),所以这些值看起来都很大。

我还将检查CPU字段,因为一个查询虽然执行速度很快,但是可能会消耗很多的CPU时间。繁重的CPU查询通常会在服务器特别繁忙而无法给它们提供足够CPU容量时发生停顿;因此,需要重写这些查询,使它们减少CPU使用,从而提高性能。Profiler支持创建过滤器。我通常先创建一个过滤器,隐藏所有小于5,000毫秒的查询,这样我就能够关注那些执行时间较长的查询。

总而言之,可以检查的项目有很多,但是这些问题的大多数解决方法都是由应用程序开发人员实现的:

在存储过程之外执行的临时SQL查询。存储过程几乎总是具有较优的性能,因为SQL Server能够缓存它们的执行计划;如果可能,临时查询应该转换为存储过程。

执行计划中的执行时间较长和CPU使用繁重的查询。表扫描操作表示缺少有效的索引,通过增加索引而消除表扫描操作,会立刻对性能带来下面影响。

包含大量联合的查询。联合耗费时间,而大量联合可能大大减慢执行速度。我一般最多采用7个联合;如果超过7个,那么一定要截短。

执行速度总是很慢的查询。重写这个查询可能会提高性能。有时候执行较慢的查询很可能是受到外部因素的影响,如锁或资源争夺。

查询性能优化并非什么科学研究,实际上它属于应用程序开发人员的职责。数据库人员的目标是确定执行速度较慢或者占用CPU严重的查询,收集证据,然后与开发人员一起确定解决问题的方法。

其他确定不良查询的好工具

虽然SQL Profiler是很好的工具,但是它实际上并不能直接帮您找到速度较慢的查询;您需要自己检查数据Profiler捕捉的数据,然后确定哪些查询是“慢的”。如果查询故障修复成为您的日常工作,那么您可能希望寻求其他专门执行查询优化的工具。

这些工具是由第三方软件供应商编写的,可以专门用来捕捉与Profiler相同的数据(其中一些实际上接受Profiler捕捉文件作为输入),然后为您确定那些性能不佳的查询。在许多时候,这些工具能够确定为什么某个查询的性能不佳,甚至会给出一些提高性能的修改建议。

这个领域的供应商包括SQL Sentry、Red Gate、Idera、Quest Software、DBSophic等。那么能够与SQL Profiler交互的工具,或者完全替代它的工具,都具有自动执行查询分析和规范建议的功能。如果是刚开始与供应商进行售前沟通,那么您一定要问清楚,在分析生产服务器时,这个产品会对性能造成什么样的影响(如果有)。有一些供应商会采用一些方法减小或消除对生产环境的影响,而这些方法总是很不错的。

本文作者:网友 来源:IT新闻网
CIO之家 www.ciozj.com 微信公众号:imciow
   
免责声明:本站转载此文章旨在分享信息,不代表对其内容的完全认同。文章来源已尽可能注明,若涉及版权问题,请及时与我们联系,我们将积极配合处理。同时,我们无法对文章内容的真实性、准确性及完整性进行完全保证,对于因文章内容而产生的任何后果,本账号不承担法律责任。转载仅出于传播目的,读者应自行对内容进行核实与判断。请谨慎参考文章信息,一切责任由读者自行承担。
延伸阅读