-
sqlSERVER如何查看索引缺失第一种是使用DMV第二种是使用DTA (database engine tuning advisor) 数据库引擎优化顾问这篇文章主要讲第一种他的性能能提高多少 www.2cto.comsqlSERVER有几个动态管理视图sys.dm_db_missing_index_detailssys.dm_db_missing_index_groupssys.dm_db_missing_index_group_statssys.dm_db_missing_index_columns(index_handle)sys.dm_db_missing_index_details以下是这个DMV的各个字段的解释:1、index_handle:标识特定的缺失索引。该标识符在服务器中是唯一的。index_handle 是此表的密钥2、database_id :标识带有缺失索引的表所驻留的数据库3、object_id :标识索引缺失的表4、equality_columns:构成相等谓词的列的逗号分隔列表 即哪个字段缺失了索引会在这里列出来(简单来讲就是where 后面的筛选字段),谓词的形式如下:table.column =constant_value5、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_columns(index_handle)字段解释index_handle:唯一地标识缺失索引的整数。sys.dm_db_missing_index_groups返回有关特定缺失索引组中包含的缺失索引(不包括空间索引)的信息sys.dm_db_missing_index_group_stats有一个字段比较重要:下面是MSDN给出的示例,缺失索引组句柄为 22 USE [AdventureWorks]3 GO4 SELECT migs.group_handle,mid.*5 FROM sys.dm_db_missing_index_group_stats AS migs6 INNER JOIN sys.dm_db_missing_index_groups AS mig7 ON (migs.group_handle = mig.index_group_handle)8 INNER JOIN sys.dm_db_missing_index_details AS mid9 ON (mig.index_handle = mid.index_handle)10 WHERE migs.group_handle = 2
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。