SQLSERVER如何查看索引缺失

当大家发现数据库查询性能很慢的时候,大家都会想到加索引来优化数据库查询性能,

但是面对一个复杂的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:索引缺失的表的名称

比如下面这个查询结果

那么应该创建这样的索引

1 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

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

示例代码:

1 USE [AdventureWorks] --要查询索引缺失的数据库
2 GO
3 SELECT * FROM sys.[dm_db_missing_index_details]
4 SELECT * FROM sys.[dm_db_missing_index_groups]
5 SELECT * FROM sys.[dm_db_missing_index_group_stats]
6 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

转自:http://www.cnblogs.com/lyhabc/archive/2013/02/10/2909761.html

SQLSERVER如何查看索引缺失的更多相关文章

  1. SqlServer中查看索引的使用情况

    --查看数据库索引的使用情况 select db_name(database_id) as N'TOPK_TO_DEV', --库名 object_name(a.object_id) as N'Top ...

  2. (4.6)sql server索引缺失提示

    SQLSERVER如何查看索引缺失 sql server索引缺失提示 当大家发现数据库查询性能很慢的时候,大家都会想到加索引来优化数据库查询性能, 但是面对一个复杂的SQL语句,找到一个优化的索引组合 ...

  3. 利用sys.dm_db_index_physical_stats查看索引大小/碎片等信息

    我们都知道,提高sql server的数据查询速度,最有效的方法,就是为表创建索引,而我们对数据表进行新增,删除,修改的时候,会产生索引碎片,索引碎片多了,对性能产生很大的影响,索引碎片越多对数据库查 ...

  4. SQLServer → 09:索引

    一.索引概念 用途 我们对数据查询及处理速度已成为衡量应用系统成败的标准,而采用索引来加快数据处理速度通常是最普遍采用的优化方法. 概念 索引是一个单独的,存储在磁盘上的数据结构,它们包含则对数据表里 ...

  5. ORACLE 如何查看索引重建进度情况

    在ORACLE数据库中,如果一个比较大的索引在重建过程中耗费时间比较长,那么怎么查看索引重建耗费的时间,以及完成了多少(比例)了呢,我们可以通过V$SESSION_LONGOPS视图来查看索引重建的时 ...

  6. mysql 查看 索引

    查看索引 mysql> show index from tblname; mysql> show keys from tblname; · Table 表的名称. · Non_unique ...

  7. 利用sys.dm_db_index_physical_stats查看索引碎片等数据(转)

    我们都知道,提高sql server的数据查询速度,最有效的方法,就是为表创建索引,而索引在对数据进行新增,删除,修改的时候,会产生索引碎片,索引碎片多了,就需要重新组织或重新生成索引,以达到索引的最 ...

  8. SQLSERVER图片查看工具SQL Image Viewer5.5.0.156

    原文:SQLSERVER图片查看工具SQL Image Viewer5.5.0.156 SQLSERVER图片查看工具SQL Image Viewer5.5.0.156 在2013年某一次北京SQL ...

  9. MySQL查看索引、表信息、触发器

    查看索引: select * FROM information_schema.TABLE_CONSTRAINTS ; select * FROM information_schema.TABLE_CO ...

随机推荐

  1. Sqlserver 函数

    SQL2008 表达式:是常量.变量.列或函数等与运算符的任意组合. 1. 字符串函数 函数 名称 参数 示例 说明 ascii(字符串表达式) select ascii('abc') 返回 97 返 ...

  2. 第一章:UNIX基础知识

    本章内容主要是为了学习UNIX的基本知识和一些最基本的系统函数. 学习的关键就是跟随者书本敲代码.本节遇到的第一个问题就死本书的apue.h这个文件:一开始没有注意这个文件,盲目的去百度,一番百度之后 ...

  3. A log about Reading the memroy of Other Process in C++/WIN API--ReadProcessMemory()

    Memory, is a complex module in Programing, especially on Windows. This time, I use cpp with win wind ...

  4. 在apache中设置访问目录后进入的默认页面为index.php

    找到apache的配置文件httpd.conf后找到 DirectoryIndex index.html index.php 在其中添加index.php,

  5. 迭代器模式(Iterator Pattern)

    迭代器模式(Iterator),提供一种方法顺序访问一个聚合对象中的各种元素,而又不暴露该对象的内部表示. 迭代器模式(Iterator)就是分离了聚合对象的遍历行为,抽象出一个迭代器来负责这样既可以 ...

  6. ubuntu 16.04 启用root用户方法

    引用:http://blog.csdn.net/sunxiaoju/article/details/51993091 1.使用:sudo passwd root设置root的密码,如下图所示: 2.使 ...

  7. 数据库设计与 ER 模型 - 数据库系统原理

    数据库系统生存周期 数据库应用系统的开发是一项软件工程,一般具有信息的采集.组织.加工.抽取.综合.传播等功能,但又有自己的特点,所以称为 数据库工程. 数据库应用系统从开始规划.设计.实现.维护到最 ...

  8. BarTender是怎么做出雪花状文字

    一些小伙伴在做标签时,发现有的人做的标签上的文字颜色不是纯色的,问我是怎么做的.这种雪花状文字要设置出来其实很简单,只要用到字体颜色填充工具就可以了.下面,小编就来给大家简单介绍一下BarTender ...

  9. 如何给Visual Studio 2015安装XNA4.0

    从这个地址下载安装包 https://mxa.codeplex.com/releases/view/618279 按照说明步骤依次安装 DirectX XNA Framework 4.0 Redist ...

  10. MYCAT 配置(转)

     server.xml配置 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mycat:se ...