查找没有索引的表

ZDNet软件频道 时间:2003-05-15 作者:翻译:Java研究组织barney |  我要评论()
本文关键词:sqltips
索引是提高SQL Server性能的关键。也许你已经接手了一个新的SQL Server,它是其他部门的或者你的公司渴望提高当前SQL Server性能的。无论怎么样,我们要完成的首要任务之一是看那些没有包含索引的表是否存在。
本文译自Builder.com,未经许可请勿转载索引是提高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属性来查找那些没有索引簇的表。



责任编辑:炒饭

欢迎评论或投稿


百度大联盟认证黄金会员Copyright© 1997- CNET Networks 版权所有。 ZDNet 是CNET Networks公司注册服务商标。
中华人民共和国电信与信息服务业务经营许可证编号:京ICP证010391号 京ICP备09041801号-159
京公网安备:1101082134