查找没有索引的表

王朝other·作者佚名  2008-05-19
窄屏简体版  字體: |||超大  

索引是提高SQL Server性能的关键。也许你已经接手了一个新的SQL Server,它是其他部门的或者你的公司渴望提高当前SQL Server性能的。无论怎么样,我们要完成的首要任务之一是看那些没有包含索引的表是否存在。

你打开两个系统表:sysindexes and sysobjects,查找这些信息。这系统表sysobjects是用来查找表对象和获得表对象名的。sysobjects 表Xtype列有一个’U’区别用户表。sysobjects 表的Id列是用来作为OBJECTPROPERTY()系统函数的参数,去查找没有索引的表的。第二个参数有TableHasIndex的值。是个系统函数如果返回0,这表示表没有索引存在。其他系统表,sysindexes 是用来取得表的行数的。Sysindexes系统表有一个indid的列,当indid的值为0时,表示它他是表而不是索引。Sysindexes表用来获得表的行的每一列的值。表的行越多,表的访问频率越高决定了为表加上索引提高性能的优先权。

下面的查询是用来查找没有索引的表的:

SELECT (SELECT si.rows

FROM sysindexes si

WHERE si.id = so.id and indid = 0) rows

, so.name

FROM sysobjects so

WHERE so.xtype = 'U'

AND OBJECTPROPERTY(so.id , 'TableHasIndex' ) = 0

ORDER BY 1 DESC

通过使用同样的查询,你可以用TableHasClusteredIndex替代TableHasIndex属性来查找那些没有索引簇的表。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航