SQL SERVER数据库维护与重建索引

Posted 有梦就能实现

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL SERVER数据库维护与重建索引相关的知识,希望对你有一定的参考价值。

第一步:查看是否需要维护,查看扫描密度/Scan Density是否为100%

  1. declare @table_id int
  2. set @table_id=object_id(‘表名‘)
  3. dbcc showcontig(@table_id)

第二步:重构SQL Server数据库表索引

  1. dbcc dbreindex(‘表名‘,pk_索引名,100)

重做第一步,如发现扫描密度/Scan Density还是小于100%则重构表的所有索引,并不一定能达100%。

  1. 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性能

DBCC DBREINDEX重建索引提高SQL Server性能

SQL Server查看索引重建重组索引进度

SQL Server 2005,维护计划建议

SQL Server 重建索引与重组索引区别

SQL Server重建索引与重组索引会更新统计信息吗?