赛迪网 > IT技术 数据库 > 精彩更新
  IT资讯搜索
 
IT产品搜索
[程序开发][网管世界][网络安全][数据库技术]
[操作系统][嘉宾聊天·在线访谈][活动集锦]
[精彩专题][Symantec专区][订阅IT技术周刊]
[开发论坛][网管论坛][安全论坛][数据库论坛]
[操作系统论坛][Sybase专区][IBM dW技术专区]
[病毒求助][病毒与漏洞播报][文档·源码下载]

如何识别真正的索引并可以自动创建索引

发布时间:2007.08.15 04:59     来源:赛迪网    作者:xiaozhao

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

答:按照默认设置,如果表中的某列没有索引,则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个统计。很明显,这些表的索引策略很差劲。对表及自动创建的与之相关联的统计的快速记数可以帮助您确定哪些表需要索引。 (责任编辑:卢兆林)


[ 发表评论 ] 字体[  ] [ 打印 ] [ 进入博客 ] [ 进入论坛 ]  [ 推荐给朋友 ]
  相关文章
· 使用索引查询的七个通用原则 (08-13) · 解析:合理使用索引查询的七个通用原则 (08-12)
· 清除Oracle无用的索引改善DML (08-09) · Oracle中建立索引并强制优化器使用 (03-07)
· Oracle中轻松取得建表和索引的DDL语句 (01-29) · 数据库中用跟踪数据来实现索引优化向导 (01-29)
· 在Oracle中监控和跟踪索引使用情况 (01-18) · SQL Server数据库中索引使用和优化 (01-16)
· 有时Oracle不用索引来查找数据的原因 (01-12) · 关于Oracle数据库中索引的维护经验谈 (01-10)
  客户需求反馈表
* 姓  名:
更多资料  了解方案  认识厂商
* 单位名称:
* 联系电话:
* 电子邮件:
  赛迪推荐  
  手机·资费 ·新品·导购·评测·手机资费·宽带
手机搜索  诺基亚 N73 MOTO Z6
  IT产品 ·笔记本·台式机·服务器·打印·投影
IT产品搜索 
  IT技术 ·开发·网管·安全·数据库·操作系统
  信息化 ·热点·专题·访谈·周刊·方案案例
[政务][电信][金融][农业][制造业][中小企业]
[CIO][ERP][协同][IT管理][中间件][电子商务]
[政策][地方][专家][评估][辞典][博客][社区]
· 专题:一路畅通构想曲——让出行不再遭遇堵车
· CIO工作亲历:企业ERP选型不能忽视"选人关"
· 综述:信息化建设给中国监狱带来的各种变化
· 金融业风险管理和法规遵从有五点需考虑的因素
· 保险业CIO关注:该如何建立统一高效的CRM体系
· 调查显示:多数CIO对IT规划仍存在困惑和误解
  博客·论坛 ·曾剑秋·项立刚·Java学习·网管