SQL性能优化前期准备-清除缓存、开启IO统计
来源:互联网 发布:linux执行命令后循环 编辑:程序博客网 时间:2024/06/05 02:29
如果需要进行SQl Server下的SQL性能优化,需要准备以下内容:
一、SQL查询分析器设置:
1、开启实际执行计划跟踪。
2、每次执行需优化SQL前,带上清除缓存的设置SQL。
平常在进行SQL Server性能优化时,为了确保真实还原性能问题,我们需要关闭SQL Server自身的执行计划及缓存。可以通过以下设置清除缓存。
1 DBCC DROPCLEANBUFFERS --清除缓冲区2 DBCC FREEPROCCACHE --删除计划高速缓存中的元素
3、开启查询IO读取统计、查询时间统计。
SET STATISTICS TIME ON --执行时间SET STATISTICS IO ON --IO读取
开启设置后,执行SQL效果如下:
针对其中的每个图标节点,鼠标滑上去的时候,可以看到具体的执行信息。如下图:
可以通过查看谓词、对象、输出列表,分析问题点或者创建优化索引等。
当然你也可以换一种查看方式,点击右键选择显示执行计划XML。
还有一点特别说明的是:当你SQL很长逻辑关系很复杂的时候,执行计划会是一个很大的网状关系图,你会发现在右下角有一个加号的按钮,点击后一个缩略图。通过缩略图你可以很方便的定位执行节点,用起来还比较好用。
二、针对SQL Server Profile,SQL查询跟踪器进行分析。
1、打开方式:SQL Server查询分析器->工具,SQL Profile。打开方式截图:
2、连接&特殊设置:
打开后界面如下图:
设置正确连接信息后,点击连接,弹出如下界面。按照图中操作步骤进行设置。
其中DatabaseId、HostName可以在查询分析器中进行查询,脚本如下:
1 SELECT DB_ID()2 SELECT DB_NAME()3 SELECT HOST_ID()4 SELECT HOST_NAME()
实际上HostName就是你的本机计算机名。
最终设置完之后点击运行。正常跟踪的效果如图:
重点关注其中的Duration、Writes、Reads、CPU,分析对象是TextData,及执行的语句。其中Duration为毫秒数,1000即为1秒。
——————————————————————————————————————————
应用总结&建议:
上面应用配合方式是:
1、先通过SQL查询跟踪器,跟踪出你所以执行的SQL,然后定位其中Duration比较的SQL 或者超过性能标准的SQl(比如页面访问3s、5s、8s)、报表30s等。
2、将问题SQL在查询分析器中进行分析,主要通过执行计划及IO统计定位耗时占比高及IO读取大的地方,然后逐步的调整SQL逻辑关系(比如添加业务条件过滤缩小集合,建立索引、调整like匹配等),优化后再重新进行跟踪看看是否有效果,最终达到SQL的优化目的。
写到这里,基本上我常用的SQL性能优化的方式就已经讲完了,希望给大家能提供帮助。
原文链接:http://www.cnblogs.com/Ren_Lei/p/5669662.html
- SQL性能优化前期准备-清除缓存、开启IO统计
- Drupal的性能优化-缓存的手工清除-…
- 如何开启SQLSERVER数据库缓存依赖优化网站性能
- 如何开启SQLSERVER数据库缓存依赖优化网站性能
- C#开启SQLSERVER数据库缓存依赖优化网站性能
- 前期准备
- 前期准备
- 前期准备
- 清除SQL SERVER缓存
- SQL Server 清除缓存
- 清除PL SQL缓存
- 清除sql缓存
- T-SQL系列之性能统计信息/数据库IO(MSSQL)
- Yii2开启数据表结构缓存和清除
- SQL数据库建表前期优化
- Qt模块化笔记之sql——前期准备
- 统计性能优化思路
- SQL SERVER性能优化--计划缓存和重编译
- 蓝色主题登陆页面界面模板
- Android 绘图(一) Paint
- Java Error和Exception
- Win7_64位使用Mysql Odbc
- Android 面试要点
- SQL性能优化前期准备-清除缓存、开启IO统计
- Jni反破解调研
- 104. Maximum Depth of Binary Tree
- Android 环形进度条Demo
- img标签的onerror事件
- innerText兼容处理
- 升级SDK后出现:This Android SDK requires Android ... update ADT to the latest version
- tongEASY
- jar文件读取和遍历