如何识别真实和自动创建的索引?

2016-01-29 16:06 10 1 收藏

如何识别真实和自动创建的索引?,如何识别真实和自动创建的索引?

【 tulaoshi.com - SQLServer 】

本技巧摘自SQL Server杂志的一期。如需了解更多的技巧,请访问SQL Server的使用技巧中心。

:我发现sysindexes索引表中的很多条目并不是我自己创建的。听说它们并不是真正的索引,而是SQL Server查询优化器自动创建的统计。怎样才能识别哪些是真正的索引,哪些是SQL Server自动创建的统计呢?

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/sqlserver/)

:按照默认设置,如果表中的某列没有索引,则SQL Server会自动为该列创建统计。然后,查询优化器评估该列中数据分布范围的统计信息,以选择一个更为有效的查询处理方案。分辨自动创建的统计很简单,在SQL Server 7.0和SQL Server 2000中,自动创建的统计的前缀为_WA_Sys。

您还可以使用INDEXPROPERTY()函数的IsAutoStatistics属性来区分一个索引是真正的还是自动创建的统计,让SQL Server优化器选择需要创建的统计。您还可以为您管理的数据库启用“自动创建统计表”选项。

很多人忽略了下面的明显的结论。自动创建统计的存在意味着某个真正的索引可能会从中受益。请考虑下列代码的输出:

USE tempdb
GO
IF OBJECTPROPERTY(OBJECT_ID('dbo.orders'), 'IsUserTable')=1
        DROP TABLE dbo.orders
GO
SELECT * INTO tempdb..orders FROM northwind..orders
GO
SELECT * FROM tempdb..orders WHERE orderid = 10248
GO
SELECT * FROM tempdb..sysindexes WHERE id = object_id('orders')
    AND name LIKE
'_wa_sys%'
GO

该代码在tempdb中复制Northwind Orders表,选择一行,然后检查SQL Server是否添加了一个统计。很显然,该表没有OrderId列的索引,所以SQL Server自动创建了名为_WA_Sys_OrderID_58D1301D 的统计。OrderId列统计表的存在表明Northwind Orders表将得益于附加的索引。

以下查询显示了为数据库中每个用户表自动创建的统计的数量,该数据库至少有一个自动创建的统计。

SELECT
     object_name(id) TableName
     ,count(*) NumberOfAutoStats
FROM
     sysindexes
WHERE
       OBJECTPROPERTY(id, N'IsUserTable') = 1
       AND INDEXPROPERTY ( id , name , 'IsAutoStatistics' ) = 1
GROUP BY
      object_name(id)
ORDER BY
      count(*) DESC

并不是所有的统计都可被真正的索引所替代。在某些情况下,SQL Server会为一个表自动创建超过50个统计。很明显,这些表的索引策略很差劲。对表及自动创建的与之相关联的统计的快速记数可以帮助您确定哪些表需要索引。

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/sqlserver/)

—Microsoft SQL Server开发团队

来源:http://www.tulaoshi.com/n/20160129/1497423.html

延伸阅读
标签: 电脑入门
为了保证Word文档在损坏或被非法修改后能更有效地挽回损失,用户可以启用Word2007自动创建备份文件的功能。通过启用自动创建备份文件功能,可以在每次经过修改而保存Word文档时自动创建一份备份文件,操作步骤如下所述: 第1步,打开Word2007窗口,然后依次单击Office按钮→Word选项按钮,如图1所示。 办公软件教程图1单击Word选项按...
标签: 婴儿感冒
小婴儿感冒如何识别和处理 感冒一般指上呼吸道感染,包括鼻炎、咽炎、喉炎、中耳炎、鼻窦炎等喉以上部位的感染。对大一点的孩子来说,每年都会有4~6次这样的感染。只要孩子的体温不超过38.5℃,就不需要作什么特殊的处理,注意休息,多喂水,咳嗽时对症地给点小儿止咳糖浆就行了。可对于小婴儿,即便感冒也是危险的。开始可能仅仅是鼻子有点...
解决Windows 7系统取消创建的索引方法 解决Windows 7系统取消创建的索引方法: 1、点击开始-搜索框输入索引,在上方出现的提示中选择索引选项; 2、选择索引选项以后弹出菜单,选择修改; 3、把里面各项建立索引的勾去掉, 确定即可。 让Windows7系统自动帮您拨号的方法 从Win7桌面左下角处的开始菜单进入,在...
标签: 拼布
在拿起一块布料准备裁剪时,我们首先得区分出哪个方向是径向,哪个方向是纬向, 然后才能确定纸样摆放的方向。 如果你的布料是有布边的,那很简单,和布边平行的方向就是径向,和布边垂直的是纬向。但是,如今网络上买来的小布头根本就没有布边,这又该如何识别呢? 如果布料上纱线的排列一个方向密另一个方...
标签: ASP
  创建ASP页面 在ASP页面上一切都变得非常酷。你用表单中的值来驱动对索引服务器进行查询的对象。 整个过程是这样的: ◆ 打开记录集。 ◆ 用标准ADO 方法,一步步地走过记录集。 <% "Create a Query object, initialize it using "SetQueryFromURL, and dump the object state "set the query object Set obj...

经验教程

651

收藏

22
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部