收藏本站 
广告服务 
网站地图 
>> 我们从网络和杂志上收集了近100000余篇各类电脑技术、网络技术、软件技术等方面的文章教程,我们的收录原则:不是精华拒不收录!
先飞电脑技术网技术文章
网络编程 | 网站建设 | 网络技术 | 设计教程 | 软件教学 | 程序开发 | 数据库开发 | 教育认证 | 硬件维护 | 媒体动画 | 机械电子 |
识别真正的索引并可以自动创建索引
[ 作者:佚名    转贴自:网络转载    阅读次数:77    更新时间:2007-8-15 11:33: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个统计。很明显,这些表的索引策略很差劲。对表及自动创建的与之相关联的统计的快速记数可以帮助您确定哪些表需要索引。

【加入到收藏夹】告诉好友】【打印此文】【关闭窗口
  版权声明:本站提供的“识别真正的索引并可以自动创建索引”版权归文章所有者,转载请注明出处!
 ·上一篇文章:在运行SQL的机器上运行病毒扫描软件      ·下一篇文章:巧妙利用SQL Server的EXISTS结构
相关文章
·准确识别QQ盗号陷阱的方法[45]
·使用指纹识别器轻松登陆Vista[24]
·让Vista系统只能识别自己指定的U盘[80]
·YouTube开发视频指纹识别技术[93]
·域名密钥识别邮件技术加速对抗垃圾邮件[68]
网站主页 | 收藏本页 | 联系我们 | 广告服务 | 站点地图 | 会员注册 | 招聘信息 | 内容指正

联系QQ:先飞电脑技术网站事务联系QQ,点击可以直接留言. 32933427 电话:13710542091 [世界排名] 鄂ICP备05005890号