SQL SERVER数据库维护与重建索引
Posted 有梦就能实现
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL SERVER数据库维护与重建索引相关的知识,希望对你有一定的参考价值。
第一步:查看是否需要维护,查看扫描密度/Scan Density是否为100%
- declare @table_id int
- set @table_id=object_id(‘表名‘)
- dbcc showcontig(@table_id)
第二步:重构SQL Server数据库表索引
- dbcc dbreindex(‘表名‘,pk_索引名,100)
重做第一步,如发现扫描密度/Scan Density还是小于100%则重构表的所有索引,并不一定能达100%。
- dbcc dbreindex(‘表名‘,‘‘,100)
重建数据库所有表的索引
USE My_Database; DECLARE @name varchar(100)
DECLARE authors_cursor CURSOR FOR Select [name] from sysobjects where xtype=‘u‘ order by id
OPEN authors_cursor
FETCH NEXT FROM authors_cursor INTO @name
WHILE @@FETCH_STATUS = 0 BEGIN
DBCC DBREINDEX (@name, ‘‘, 90)
FETCH NEXT FROM authors_cursor INTO @name END
deallocate authors_cursor
参考:
DBCC SHOWCONTIG (Transact-SQL) http://msdn.microsoft.com/zh-cn/library/ms175008(v=sql.90).aspx
DBCC DBREINDEX (Transact-SQL) http://msdn.microsoft.com/zh-cn/library/ms181671(v=sql.90).aspx
以上是关于SQL SERVER数据库维护与重建索引的主要内容,如果未能解决你的问题,请参考以下文章
DBCC DBREINDEX重建索引提高SQL Server性能