≡
  • 网络编程
  • 数据库
  • CMS技巧
  • 软件编程
  • PHP笔记
  • JavaScript
  • MySQL
位置:首页 > 数据库 > SQL Server

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

人气:440 时间:2020-04-16

这篇文章主要为大家详细介绍了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

本文来自:http://www.q1010.com/179/8554-0.html

注:关于SQLSERVER如何查看索引缺失及DMV使用介绍的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。

关键词:SQL SERVER

您可能感兴趣的文章

  • SqlServer系统数据库的作用深入了解
  • SqlServer数据库全角转换成半角
  • oracle,mysql,SqlServer三种数据库的分页查询的实例
  • SQLSERVER的排序问题结果不是想要的
  • SqlServer 扩展属性的介绍
  • 真正高效的SQLSERVER分页查询(多种方案)
  • sqlserver (parse name)字符串截取的方法
  • sqlserver数据库出现置疑的解决思路
  • sqlserver中delete、update中使用表别名和oracle的区别
  • SqlServer获取存储过程返回值的实例
上一篇:SQL里面用自定义Split()完成个性化需求
下一篇:SqlServer系统数据库的作用深入了解
热门文章
  • SQL Server SQL获取第一条记录的方法
  • SQL Server出现System.OutOfMemoryException异常的解决方法
  • SQL Server的 update from 语句的简单示例
  • SQL Server 数据库备份方法菜鸟教程
  • SQL Server 多表关联时在where语句中慎用trim()方法
  • SQL Server数据类型及长度限制详细说明
  • mybaits非配置原因,导致SqlSession was not registered for synchronization异常解析
  • SQL Server 收缩后对数据库的使用有影响吗?
  • SQL Server 格式导致的Excel导入sql出现异常的解决方法
  • SQL Server 连接服务器出现错误 7391的解决方法
  • 最新文章
    • SQL Server存储过程基本语法的简单示例
    • sql查询时增加自动编号和分页的简单示例
    • sql轻松应付百万数据的高效数据分页存储过程的简单示例
    • sql获取一条数据中所有字段的名称和值的实现方法
    • sql分割函数的简单示例
    • SQL Server异常捕获的简单示例
    • SQL SERVER回滚恢复误操作数据的实现方法
    • SQL Server函数或存储过程中抛出异常的实现方法
    • SQL Server创建数据库的完整代码
    • SQL Server创建数据库的命令用法示例

四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。