您好,欢迎访问一九零五行业门户网

SQLSERVER如何查看索引缺失

sqlserver如何查看索引缺失 当大家发现数据库查询性能很慢的时候,大家都会想到加索引来优化数据库查询性能, 但是面对一个复杂的sql语句,找到一个优化的索引组合对人脑来讲,真的不是一件很简单的事。 好在sqlserver提供了两种自动功能,给你建议,该怎么
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:索引缺失的表的名称
比如下面这个查询结果
那么应该创建这样的索引
idx_salesorderdetail_test_productid_includeindex on salesorderdetail_test(productid) include(salesorderid) ,美国空间
其它类似信息

推荐信息