如何识别真实和自动创建呢

电工电气2021年09月06日

行李中不能夹带毕业证、派遣证、身份证、现金等贵要物品。(翟烜) 问:最近我发现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(\'ders\'), \'IsUserTable\')=1  DROP TABLE ders  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个统计。很明显,这些表的索引策略很差劲。对表及自动创建的与之相关联的统计的快速记数可以帮助您确定哪些表需要索引。

孩子消化不良吃什么好
南通妇科好医院
天津哪家医院男科医院好
相关阅读
演员达式常:凭《人到中年》走红,高龄常说:今生没演够

新月卫视主持人曹可凡曾在即时通讯该平台发文:“拍片偶然达式常女士。去...

2024-03-27
魅族19疑似曝光,魅友:不在辉煌时驻足,不在低谷时转身离去

从骁龙8 Gen1中央处理器发布新闻便,市场竞争中依然都从未关于Lumia全面性的...

2024-01-08
Polycom宝利通soundstation2基本型/标准型/引入型八爪鱼会议电话简要说明书

近期杭州利旺智能科技合资集团浙江视频决议网易收到苏州市一企业客户咨询...

2023-12-09
祥硕将发表USB 4主机控制器芯片组

2022-05-22 10:25:20 作者:吕英娜 ASMedia)正式宣布成为首家推出USB 4PC伺服芯片组...

2023-11-19
2022年家居风靡一时趋势

人性化个性化。全屋个性化已迅速视作家装边缘化趋势,全屋个性化可以根据...

2023-11-18
情感之公事,合则双利

最后往往都是爱得最深的那个人中枪,因为太爱,所以会疼。爱一个人久了,...

2023-11-15
友情链接