使用SQL Server动态管理视图的方法

我们可以使用SQL Server动态管理视图确认缺失索引,下面就对这种SQL Server动态管理视图的方法作详细的介绍,供您参考。

由于有了很多新功能,我们可以看到在SQL Server 2005和现在有SQL Server 2008中,Microsoft引进了一些动态管理视图来协助确认基于查询历史的可能索引候选人。

这些动态管理视图是:

n sys.dm_db_missing_index_details –返回关于缺失索引的详细信息。

n sys.dm_db_missing_index_group_stats – 返回缺失索引组的摘要信息

n sys.dm_db_missing_index_groups – 返回一个具体组的缺失索引的信息。

n sys.dm_db_missing_index_columns(index_handle) – 返回在一个索引中缺失的数据库表列的信息。这是一个函数,它要求传递index_handle。

和大多数动态管理视图的跟踪统计数据一样,当SQL Server实例重启,这些数据被完全清除时,这些工作方式基本上是一样的。所以如果你在一个测试环境中工作并且重启你的SQL Server实例,那么这些视图有可能不返回数据。

为了启动,我们将使用一个从SQL Server 2005联机帮助中得到的实例,这要求从AdventureWorks数据库中查询一张表而在StateProvinceID上没有索引,如下所示:

  1.  USE AdventureWorks;  
  2. GO  
  3. SELECT City, StateProvinceID, PostalCode  
  4. FROM Person.Address  
  5. WHERE StateProvinceID = 1;  
  6. GO 

一旦我们运行了上面的查询,数据在动态管理视图中应该可用。让我们来快速看下每一个查询。

第一个查询从sys.dm_db_missing_index_details视图中获取数据。这可能是最有用的一个查询,因为这给我们展示了 object_id、equality_columns 和inequality_columns。另外,我们可以得到关于所含列的其它具体信息。

  1. SELECT * FROM sys.dm_db_missing_index_details 

 

图一

所以从上面我们执行的查询中,我们可以看到下面的信息:

n equality_columns = “StateProvinceID”,这是因为这个字段和一个相等运算符在WHERE从句中使用。所以SQL Server告诉我们这将是针对索引的很好的选择。

n inequality_columns = “NULL”,如果你使用其它的运算符比如不相等,那么这个字段将会有数据,但是由于我们使用等号,因此没有一个字段将在这里使用。

n included_columns =这是当创建一个索引时使用的其它字段。由于这个查询只使用City、StateProvinceID 和 PostalCode,因此StateProvinceID将在索引中得到处理,当该索引创建时,其它两个字段可能被用作内嵌的字段。

下一个索引从sys.dm_db_missing_index_group_stats中获取数据。这个查询使我们更了解其他统计数据,例如编译,用户查找, 用户扫描等,所以从这里我们可以知道这个查询多久会被访问。如果我们创建一个基于这些信息的新索引,这将帮助我们确定多久使用一个索引可以获得数据。

  1. SELECT * FROM sys.dm_db_missing_index_group_stats 

由于这个查询我们只执行了一次,因此我们的unique_compiles = 1 ,我们的 user_seeks = 1。如果我们再次运行这个查询,我们的user_seeks应该会增加。

图二

下一个视图sys.dm_db_missing_index_groups将会给我们提供index_group_handle 和 index_handle的信息。

  1. SELECT * FROM sys.dm_db_missing_index_groups 

图三

从上面查询得到的结果基本上将用于从sys.dm_db_missing_index_columns函数中获得数据。index_handle值被传递到下一个查询,如下图所示。

  1. SELECT * FROM sys.dm_db_missing_index_columns(1) 

图四

要得到在一个结果集显示的所有数据,下面从SQL Server 2005联机帮助中得到的查询将为我们提供这些数据。

  1. SELECT mig.*, statement AS table_name,  
  2. column_id, column_name, column_usage  
  3. FROM sys.dm_db_missing_index_details AS mid  
  4. CROSS APPLY sys.dm_db_missing_index_columns (mid.index_handle)  
  5. INNER JOIN sys.dm_db_missing_index_groups AS mig ON mig.index_handle = mid.index_handle  
  6. ORDER BY mig.index_group_handle, mig.index_handle, column_id; 

图五

总结

n 基于这个例子我们可以看到,我们可以在表AdventureWorks.Person.Address的字段StateProvinceID上创建一个新索引,也可以包括columns City和PostalCode。

n 要注意的是当你在一张表中增加或者删除索引时,缺失索引的所有统计数据将在这张表中完全清除。

n 尽管这可能不是完美的,也存在一些局限,但是这至少让我们了解了之前使用SQL Server旧版本时从来不知道的信息。

 

 

 

 

【编辑推荐】

SQL Server资源锁模式大全

SQL Server查询结果集中的常量

sql server查询平均值的实现

SQL Server FROM子句的语法

SQL Server查询累计值的实现

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/288317.html<

(0)
运维的头像运维
上一篇2025-05-16 06:44
下一篇 2025-05-16 06:45

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注