打造金坛城市门户网

热门搜索: 活动 交友 车展 出租 出售 优惠

查看: 19546|回复: 3

[电脑软件] sql server如何识别真实和自动创建的索引

[复制链接]

82

主题

1522

帖子

115

积分

从九品:吏目

Rank: 2

发表于 2010-11-13 09:44:22 | 显示全部楼层 |阅读模式

注册成为金坛论坛会员,与千万金坛网友开启缘分旅程!

您需要 登录 才可以下载或查看,没有帐号?现在注册

x
问:我发现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个统计。很明显,这些表的索引策略很差劲。对表及自动创建的与之相关联的统计的快速记数可以帮助您确定哪些表需要索引。
金坛论坛——贴近生活,服务百姓,信息服务金坛!
回复

使用道具 举报

7

主题

1453

帖子

69

积分

从九品:吏目

Rank: 2

发表于 2019-7-24 12:26:41 | 显示全部楼层
必须赞一个。。。
金坛论坛——贴近生活,服务百姓,信息服务金坛!
回复 支持 反对

使用道具 举报

53

主题

1419

帖子

83

积分

从九品:吏目

Rank: 2

发表于 2019-7-24 13:06:13 | 显示全部楼层
必须赞一个。。。
金坛论坛——贴近生活,服务百姓,信息服务金坛!
回复 支持 反对

使用道具 举报

2

主题

951

帖子

88

积分

从九品:吏目

Rank: 2

零距离108将 之 地平星·铁臂膊·蔡福

发表于 2019-7-24 13:06:31 | 显示全部楼层
必须赞一个。。。
金坛论坛——贴近生活,服务百姓,信息服务金坛!
回复 支持 反对

使用道具 举报

使用 高级模式(可批量传图、插入视频等)
您需要登录后才可以回帖 登录 | 现在注册

快速回复 返回顶部 返回列表