数据库

位置:IT落伍者 >> 数据库 >> 浏览文章

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


发布日期:2021年08月04日
 
sql server如何识别真实和自动创建的索引

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

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

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

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

USE tempdb

GO

IF OBJECTPROPERTY(OBJECT_ID(dboorders) IsUserTable)=

DROP TABLE dboorders

GO

SELECT * INTO tempdborders FROM northwindorders

GO

SELECT * FROM tempdborders WHERE orderid =

GO

SELECT * FROM tempdbsysindexes WHERE id = object_id(orders)

AND name LIKE

_wa_sys%

GO

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

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

SELECT

object_name(id) TableName

count(*) NumberOfAutoStats

FROM

sysindexes

WHERE

OBJECTPROPERTY(id NIsUserTable) =

AND INDEXPROPERTY ( id name IsAutoStatistics ) =

GROUP BY

object_name(id)

ORDER BY

count(*) DESC

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

—Microsoft SQL Server开发团队

上一篇:SQLServer数据库的攻击分析

下一篇:UDF—MSQL Server 2000的新特性