拼吾爱程序人生

首页 » 数据库编程 » SQL » 如何识别真实和自动创建的索引?
Systemjudge - 2007-8-6 17:00:00
问:我发现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个统计。很明显,这些表的索引策略很差劲。对表及自动创建的与之相关联的统计的快速记数可以帮助您确定哪些表需要索引。 
—Microsoft SQL Server开发团队

 您可能对 [SQL] 的这些文章也感兴趣:

批量更改数据库对象所有者nf_ChangeObjectOwner
SQL字符串函数
优化数据库前,问自己10个问题
网络SQL入侵与防范高级篇
使用ODC文档在IE中直接连接SQL数据库
将表数据生成SQL脚本的存储过程
利用MSSQL sp自制未公开的加密函数
启动SQL SERVER时自动执行存储过程
存储过程编写经验和优化措施
利用SQL移动硬盘文件
SQL语言入门教程:第五课 删除数据库表格
Sql语句密码验证的安全漏洞
1
查看完整版本: 如何识别真实和自动创建的索引?
Modify by pin5i DZNT_ExpandPackage 2.1.3295 2007-2009 pin5i.com
 Total Unique Visitors: