• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    SQLSERVER如何查看索引缺失及DMV使用介绍

    当大家发现数据库查询性能很慢的时候,大家都会想到加索引来优化数据库查询性能,但是面对一个复杂的SQL语句,找到一个优化的索引组合对人脑来讲,真的不是一件很简单的事。

    好在SQLSERVER提供了两种“自动”功能,给你建议,该怎么调整索引

    第一种是使用DMV

    第二种是使用DTA (database engine tuning advisor) 数据库引擎优化顾问

    这篇文章主要讲第一种


    SQL2005以后,在SQLSERVER对任何一句语句做编译的时候,都会去评估一下,

    这句话是不是缺少什么索引的支持,如果他认为是,他还会预估,如果有这麽一个索引

    他的性能能提高多少

    SQLSERVER有几个动态管理视图

    sys.dm_db_missing_index_details

    sys.dm_db_missing_index_groups

    sys.dm_db_missing_index_group_stats

    sys.dm_db_missing_index_columns(index_handle)


    sys.dm_db_missing_index_details

    这个DMV记录了当前数据库下所有的missing index的信息,他针对的是SQLSERVER从启动以来所有运行的语句,

    而不是针对某一个查询。DBA可以看看,哪些表格SQLSERVER对他是最有“意见”的

    以下是这个DMV的各个字段的解释:

    1、index_handle:标识特定的缺失索引。该标识符在服务器中是唯一的。index_handle 是此表的密钥

    2、database_id :标识带有缺失索引的表所驻留的数据库

    3、object_id :标识索引缺失的表

    4、equality_columns:构成相等谓词的列的逗号分隔列表 即哪个字段缺失了索引会在这里列出来(简单来讲就是where 后面的筛选字段),

    谓词的形式如下:table.column =constant_value

    5、inequality_columns :构成不等谓词的列的逗号分隔列表,例如以下形式的谓词:table.column > constant_value “=”之外的任何比较运算符都表示不相等。

    6、included_columns:用于查询的涵盖列的逗号分隔列表(简单来讲就是 select 后面的字段)。

    7、statement:索引缺失的表的名称

    比如下面这个查询结果

    那么应该创建这样的索引

    复制代码 代码如下:

    CREATE INDEX idx_SalesOrderDetail_test_ProductID_IncludeIndex ON SalesOrderDetail_test(ProductID) INCLUDE(SalesOrderID)

    在ProductID上创建索引,SalesOrderID作为包含性列的索引

    注意事项:

    由 sys.dm_db_missing_index_details 返回的信息会在查询优化器优化查询时更新,因而不是持久化的。

    缺失索引信息只保留到重新启动 SQL Server 前。如果数据库管理员要在服务器回收后保留缺失索引信息,

    则应定期制作缺失索引信息的备份副本


    sys.dm_db_missing_index_columns(index_handle)

    返回与缺少索引(不包括空间索引)的数据库表列有关的信息,sys.dm_db_missing_index_columns 是一个动态管理函数

    字段解释

    index_handle:唯一地标识缺失索引的整数。


    sys.dm_db_missing_index_groups

    返回有关特定缺失索引组中包含的缺失索引(不包括空间索引)的信息


    sys.dm_db_missing_index_group_stats

    返回缺失索引组的摘要信息,不包括空间索引

    这个视图说白了就是预估有这麽一个索引,他的性能能提高多少

    有一个字段比较重要:

    avg_user_impact: 实现此缺失索引组后,用户查询可能获得的平均百分比收益。该值表示如果实现此缺失索引组,则查询成本将按此百分比平均下降。

    就是说,增加了这个缺失索引,性能可以提高的百分比

    下面是MSDN给出的示例,缺失索引组句柄为 2

    复制代码 代码如下:

    --查询提供缺失索引的数据库、架构和表的名称。它还提供应该用于索引键的列的名称
    USE [AdventureWorks]
    GO
    SELECT migs.group_handle, mid.*
    FROM sys.dm_db_missing_index_group_stats AS migs
    INNER JOIN sys.dm_db_missing_index_groups AS mig
    ON (migs.group_handle = mig.index_group_handle)
    INNER JOIN sys.dm_db_missing_index_details AS mid
    ON (mig.index_handle = mid.index_handle)
    WHERE migs.group_handle = 2

    示例代码:

    复制代码 代码如下:

    USE [AdventureWorks] --要查询索引缺失的数据库
    GO
    SELECT * FROM sys.[dm_db_missing_index_details]
    SELECT * FROM sys.[dm_db_missing_index_groups]
    SELECT * FROM sys.[dm_db_missing_index_group_stats]
    SELECT * FROM sys.[dm_db_missing_index_columns](1) --1 :1是根据dm_db_missing_index_details查出来的

    我估计XX大侠做的SQLSERVER索引优化器也使用了"sys.dm_db_missing_index_details" 这个DMV

    刚才看了一下,好像有错别字:Total Cost不是Totol Cost

    暂时不知道Total Cost跟Improvement Measure怎麽算出来的

    注意:

    最后大家还需要注意一下,虽然这些DMV给出的建议还是比较合理的。

    但是,DBA还是需要去确认一下建议。因为这个建议完全是根据语句本身给出的,

    没有考虑对其他语句的影响,也没有考虑维护索引的成本,所以是很片面的。

    其准确性,也要再确认一下

    上面几个DMV的字段解释,大家可以看一下MSDN,非常详细

    sys.dm_db_missing_index_group_stats
    msdn:http://msdn.microsoft.com/zh-cn/library/ms345421.aspx

    sys.dm_db_missing_index_groups
    msdn:http://msdn.microsoft.com/zh-cn/library/ms345407.aspx

    sys.dm_db_missing_index_columns([sql_handle])
    msdn:http://msdn.microsoft.com/zh-cn/library/ms345364.aspx

    sys.dm_db_missing_index_details
    msdn:http://msdn.microsoft.com/zh-cn/library/ms345434.aspx

    您可能感兴趣的文章:
    • 浅析SQL Server 聚焦索引对非聚集索引的影响
    • 浅述SQL Server的聚焦强制索引查询条件和Columnstore Index
    • 浅析SQL Server的聚焦使用索引和查询执行计划
    • 详解sqlserver查询表索引
    • SQL SERVER 2008 R2 重建索引的方法
    • SQLSERVER全文目录全文索引的使用方法和区别讲解
    • SQL_Server全文索引的使用实例演示
    • SQL_Server全文索引的用法解析
    • SQLSERVER对索引的利用及非SARG运算符认识
    • sqlserver索引的原理及索引建立的注意事项小结
    • sqlserver2005自动创建数据表和自动添加某个字段索引
    • SQL Server 数据库索引其索引的小技巧
    • 详解SQL Server的聚焦过滤索引
    上一篇:诊断SQLSERVER问题常用的日志概述及使用
    下一篇:SQLSERVER记录登录用户的登录时间(自写脚本)
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    SQLSERVER如何查看索引缺失及DMV使用介绍 SQLSERVER,如何,查看,索引,