原文:第七章——DMVs和DMFs(2)——用DMV和DMF监控索引性能

本文继续介绍使用DMO来监控,这次讲述的是监控索引性能。索引是提高查询性能的关键性手段。即使你的表上有合适的索引,你也要时时刻刻进行索引维护任务。

SQLServer有专门的DMO来显示索引相关统计信息。能帮助你分析现有索引的性能情况。通过这些DMO,可以做到:

Ø  检查索引使用模式

Ø  查找丢失索引

Ø  查找无用索引

Ø  查找索引碎片

Ø  分析索引页分配明细

本文将使用这些DMO来检查数据库的丢失索引,索引上的查找和扫描操作,并分析索引碎片是否有必要重组或重建。

准备工作:

下面的例子将演示如何通过DMO来找到丢失索引,丢失索引是不存在但创建后可以提高查询性能的索引。

同时可以看到如何查找索引使用明细和碎片明细,对索引维护工作很有帮助。

本文将使用SQLServer 2008R2和示例数据库AdventureWorks来演示。

步骤:

1、 
打开SSMS并连到SQLServer,选择AdventureWorks数据库。

2、 
在新窗口中输入以下代码:

  1. USE AdventureWorks
  2. GO
  3. SELECT SalesOrderID ,
  4. SalesOrderDetailID ,
  5. OrderQty ,
  6. ProductID
  7. FROM Sales.SalesOrderDetail
  8. WHERE ModifiedDate >= '2004-01-01 00:00:00.000'
  9. GO
  10.  
  11. SELECT SalesOrderDetailID ,
  12. UnitPrice ,
  13. UnitPriceDiscount
  14. FROM Sales.SalesOrderDetail
  15. WHERE ProductID = 921
  16. GO

3、 
在另外一个窗口输入以下代码来查找缺失索引的情况:

  1. SELECT MID.statement AS ObjectName ,
  2. MID.equality_columns ,
  3. MID.inequality_columns ,
  4. MID.included_columns ,
  5. MIGS.avg_user_impact AS ExpectedPerformanceImprovement ,
  6. ( MIGS.user_seeks + MIGS.user_scans ) * MIGS.avg_total_user_cost
  7. * MIGS.avg_user_impact AS PossibleImprovement
  8. FROM sys.dm_db_missing_index_details AS MID
  9. INNER JOIN sys.dm_db_missing_index_groups AS MIG ON MID.index_handle = MIG.index_handle
  10. INNER JOIN sys.dm_db_missing_index_group_stats AS MIGS ON MIG.index_group_handle = MIGS.group_handle
  11. GO

4、 
为了找到索引使用明细,输入以下代码:

  1. USE AdventureWorks
  2. GO
  3. SELECT O.name AS ObjectName ,
  4. I.name AS IndexName ,
  5. IUS.user_seeks ,
  6. IUS.user_scans ,
  7. IUS.last_user_seek ,
  8. IUS.last_user_scan
  9. FROM sys.dm_db_index_usage_stats AS IUS
  10. INNER JOIN sys.indexes AS I ON IUS.object_id = I.object_id
  11. AND IUS.index_id = I.index_id
  12. INNER JOIN sys.objects AS O ON IUS.object_id = O.object_id
  13. GO

5、 
输入以下代码来查找索引碎片:

  1. USE AdventureWorks
  2. GO
  3. SELECT O.name AS ObjectName ,
  4. I.name AS IndexName ,
  5. IPS.avg_page_space_used_in_percent AS AverageSpaceUsedInPages ,
  6. IPS.avg_fragmentation_in_percent AS AverageFragmentation ,
  7. IPS.fragment_count AS FragmentCount ,
  8. suggestedIndexOperation = CASE WHEN IPS.avg_fragmentation_in_percent <= 30
  9. THEN 'ReOrganize Index'
  10. ELSE 'ReBuild Index'
  11. END
  12. FROM sys.dm_db_index_physical_stats(DB_ID(), NULL, NULL, NULL, 'DETAILED')
  13. AS IPS
  14. INNER JOIN sys.indexes AS I ON IPS.index_id = I.index_id
  15. AND IPS.object_id = I.object_id
  16. INNER JOIN sys.objects AS O ON IPS.object_id = O.object_id
  17. WHERE IPS.avg_fragmentation_in_percent > 5
  18. ORDER BY AverageFragmentation DESC
  19. GO

结果如下:

分析:

在本文中,首先在AdventureWorks库上的Sales.SalesOrderDetail表中做一些简单的查询,第一个查询是基于这个表的ModifiedDate,而第二个查询是基于ProductID。

SQLServer提供缺失索引的详细情况。缺失索引是指在数据库中不存在的索引,但是如果创建,查询将会得益并运行得更快。可以关联两个DMV,sys.dm_db_missing_index_groups和sys.dm_db_missing_index_group_stats。其中DMV,sys.dm_db_missing_index_groups_stats返回关于如果创建了缺失索引,将会对查询有多少可能性的提高的详细信息。注意从这个视图中查找的avg_user_impact列,这里间接地通过这列来和Sys.dm_db_missing_index_details与sys.dm_db_missing_index_groups关联。

和DTA(数据库优化引擎顾问)类似,DMV可能会建议广泛使用很多INCLUDE列在索引中。所以你不应该不顾一切把所有索引全部创建。因为这对你的DML操作可能会带来比较大的影响,如增删改等操作。

在第二个查询DMO中,返回了特定索引的查找和扫描数量。为了返回索引名称和对象名称,关联了sys.indexes和sys.objects这两个目录视图。

最后就是查找碎片,这里使用了DMF而不是DMV,sys.dm_db_index_physical_stats()函数。留意一下,这里使用了DB_ID()函数,因为希望得到当前数据库的所有索引信息,所以用这个函数即可。为了得到索引名和对象名,关联了sys.indexex和sys.objects目录视图。

扩充知识:

除了上面提到的DMO之外,还有两个有用的DMF来协助分析:

Ø 
Sys.dm_db_index_operational_stats

Ø 
Sys.dm_db_missing_index_columns

这两个DMF和之前提到的DMO的详细信息可查看联机丛书或者微软官网的说明。

第七章——DMVs和DMFs(2)——用DMV和DMF监控索引性能的更多相关文章

  1. 第七章——DMVs和DMFs(4)——用DMV和DMF监控磁盘IO

    原文:第七章--DMVs和DMFs(4)--用DMV和DMF监控磁盘IO 前言: 本文为本系列最后一篇,作为DBA,你必须经常关注磁盘的I/O问题,一旦出现问题,要尽快分析出是什么问题.SQLServ ...

  2. 第七章——DMVs和DMFs(3)——用DMV和DMF监控TempDB

    原文:第七章--DMVs和DMFs(3)--用DMV和DMF监控TempDB 前言: 我们都知道TempDB是SQLServer的系统数据库,且SQLServer的日常运作严重依赖这个库.因此,监控T ...

  3. 第七章——DMVs和DMFs(1)

    原文:第七章--DMVs和DMFs(1) 简介: 从SQLServer2005开始,微软引入了一个名叫DMO(动态管理对象)的新特性,DMO可以分为DMFs(Dynamic Manage Functi ...

  4. KnockoutJS 3.X API 第七章 其他技术(2) 使用扩展器来增加可观察量(监控属性)

    Knockout observables提供了支持读取/写入值并在值改变时通知订阅者所需的基本功能. 但在某些情况下,您可能希望向可观察者添加其他功能. 这可能包括通过在可观察者前面放置一个可写的计算 ...

  5. 精通Web Analytics 2.0 (9) 第七章:失败更快:爆发测试与实验的能量

    精通Web Analytics 2.0 : 用户中心科学与在线统计艺术 第七章:失败更快:爆发测试与实验的能量 欢迎来到实验和测试这个棒极了的世界! 如果Web拥有一个超越所有其他渠道的巨大优势,它就 ...

  6. 《Entity Framework 6 Recipes》中文翻译系列 (38) ------ 第七章 使用对象服务之动态创建连接字符串和从数据库读取模型

    翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 第七章 使用对象服务 本章篇幅适中,对真实应用中的常见问题提供了切实可行的解决方案. ...

  7. 《Entity Framework 6 Recipes》中文翻译系列 (41) ------ 第七章 使用对象服务之标识关系中使用依赖实体与异步查询保存

    翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 7-7  标识关系中使用依赖实体 问题 你想在标识关系中插入,更新和删除一个依赖实体 ...

  8. Java语言程序设计(基础篇) 第七章 一维数组

    第七章 一维数组 7.2 数组的基础知识 1.一旦数组被创建,它的大小是固定的.使用一个数组引用变量,通过下标来访问数组中的元素. 2.数组是用来存储数据的集合,但是,通常我们会发现把数组看作一个存储 ...

  9. objective-c第七章课后练习2

    题:改变第七章例子中print方法,增加bool参数,判断如果是YES则对分数进行约简 @interface Fraction : NSObject { //int num,den; } @prope ...

随机推荐

  1. SQLserver2012 tcp/ip 1433port问题解决方法

    非常多MSSQL安装完毕后,调用1433(默认port)是失败的,这边具体介绍下解决方法. 一..我们须要在电脑上开启telnet服务,定位问题须要.在cmd下使用telnet,假设报命令不存在说明没 ...

  2. http协议之cookie标准RFC6265介绍

      [Docs] [txt|pdf] [draft-ietf-httpst...] [Diff1] [Diff2] [Errata] PROPOSED STANDARD Errata Exist In ...

  3. ExtJS与JQuery对照

    首先在介绍ExtJS和JQuery,然后进行比较 一个.什么是ExtJS? 1.ExtJS能够用来开发RIA也即富client的AJAX应用,是一个用javascript写的,主要用于创建前端用户界面 ...

  4. 黄聪:Microsoft Enterprise Library 5.0 系列教程(三) Validation Application Block (初级)

    原文:黄聪:Microsoft Enterprise Library 5.0 系列教程(三) Validation Application Block (初级) 企业库提供了一个很强大的验证应用程序模 ...

  5. Java Evaluate Reverse Polish Notation(逆波兰式)

    表情:: ["2", "1", "+", "3", "*"] -> ((2 + 1) * 3) ...

  6. malloc功能具体解释

    一.原型:extern void *malloc(unsigned int num_bytes); 头文件:#include <malloc.h> 或 #include <alloc ...

  7. hdu 4444 Walk (离散化+建图+bfs+三维判重 好题)

    Walk Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) Total Submi ...

  8. 手机APP有三类:原生APP,WebAPP,HybridApp

    搭建 AngularJS+Ionic+Cordova 开发环境并运行一个demo 目前的手机APP有三类:原生APP,WebAPP,HybridApp:HybridApp结合了前两类APP各自的优点, ...

  9. Hibernate Tomcat JNDI数据源配置(转)

    简述: 配置JNDI 查找Tomcat 中server.xml中定义的数据源 步骤: 1. 修改elipse的数据源server.xml 主要修改如下, 1. 添加下面这段Context文本 其中St ...

  10. SPOJ PT07X Vertex Cover

    题目意思: 一棵树,找到最少的点能覆盖到所有的边,(也就是每条边俩端 至少有一个在你找到的集合): 解法:每条边只能被俩个点中的一个,或全部覆盖所以我们有树形DP来解: DP[num][flag]// ...