SQLSERVER如何查看索引缺失及DMV使⽤介绍 当⼤家发现数据库查询性能很慢的时候,⼤家都会想到加索引来优化数据库查询性能,但是⾯对⼀个复杂的SQL语句,到⼀个优化的索引组合对⼈脑来讲,真的不是⼀件很简单的事。 好在SQLSERVER提供了两种“⾃动”功能,给你建议,该怎么调整索引 这篇⽂章主要讲第⼀种
从以后,在SQLSERVER对任何⼀句语句做编译的时候,都会去评估⼀下,
这句话是不是缺少什么索引的⽀持,如果他认为是,他还会预估,如果有这麽⼀个索引
他的性能能提⾼多少
SQLSERVER有⼏个动态管理视图
这个DMV记录了当前数据库下所有的missing index的信息,他针对的是SQLSERVER从启动以来所有运⾏的语句,
⽽不是针对某⼀个查询。DBA可以看看,哪些表格SQLSERVER对他是最有“意见”的
以下是这个DMV的各个字段的解释:
1、index_handle:标识特定的缺失索引。该标识符在服务器中是唯⼀的。index_handle 是此表的密钥
2、database_id :标识带有缺失索引的表所驻留的数据库
3、object_id :标识索引缺失的表
4、equality_columns:构成相等谓词的列的逗号分隔列表即哪个字段缺失了索引会在这⾥列出来(简单来讲就是where 后⾯的筛选字段),
谓词的形式如下:lumn =constant_value
5、inequality_columns :构成不等谓词的列的逗号分隔列表,例如以下形式的谓词:lumn > 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_columns 是⼀个动态管理函数
字段解释
index_handle:唯⼀地标识缺失索引的整数。
返回有关特定缺失索引组中包含的缺失索引(不包括空间索引)的信息
返回缺失索引组的摘要信息,不包括空间索引
有⼀个字段⽐较重要:
avg_user_impact: 实现此缺失索引组后,⽤户查询可能获得的平均百分⽐收益。该值表⽰如果实现此缺失索引组,则查询成本将按此百分⽐平均下降。就是说,增加了这个缺失索引,性能可以提⾼的百分⽐
下⾯是MSDN给出的⽰例,缺失索引组句柄为 2
复制代码代码如下:
--查询提供缺失索引的数据库、架构和表的名称。它还提供应该⽤于索引键的列的名称
USE [AdventureWorks]
GO
up_handle, mid.*
FROM sys.dm_db_missing_index_group_stats AS migs
INNER JOIN sys.dm_db_missing_index_groups AS mig
ON (up_handle = mig.index_group_handle)
INNER JOIN sys.dm_db_missing_index_details AS mid
ON (mig.index_handle = mid.index_handle)
up_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查出来的
刚才看了⼀下,好像有错别字:Total Cost不是Totol Cost
暂时不知道Total Cost跟Improvement Measure怎麽算出来的
最后⼤家还需要注意⼀下,虽然这些DMV给出的建议还是⽐较合理的。
但是,DBA还是需要去确认⼀下建议。因为这个建议完全是根据语句本⾝给出的,没有考虑对其他语句的影响,也没有考虑维护索引的成本,所以是很⽚⾯的。
其准确性,也要再确认⼀下