クエリ効率を向上させるための SQL Server データベースの構文について

PS: 単一テーブルの再編成断片化インデックスは非常に単純です。
構文は次のとおりです: DBCC DBReindex(' A.dbo.C ')//A: データベース C: データベース テーブル

すべてのテーブルのインデックスとフラグメントを再構築するための構文は次のとおりです。

Use [数据库名称]
Go
DECLARE @DBCCString NVARCHAR(1000)
DECLARE @TableName VARCHAR(100)
DECLARE Cur_Index CURSOR
FOR
SELECT Name AS TblName
FROM sysobjects
WHERE xType='U'
ORDER BY TblName
FOR READ ONLY
OPEN Cur_Index
FETCH NEXT FROM Cur_Index
INTO @TableName
WHILE @@FETCH_STATUS=0
BEGIN
SET @DBCCString = 'DBCC DBREINDEX(@TblName,'''')WITH NO_INFOMSGS'
EXEC SP_EXECUTESQL @DBCCString,N'@TblName VARCHAR(100)', @TableName
PRINT '重建表' + @TableName +'的索引........OK!'
FETCH NEXT FROM Cur_Index INTO @TableName
END
CLOSE Cur_Index
DEALLOCATE Cur_Index
PRINT '操作完成!'
go


DBCC UPDATEUSAGE(0);

おすすめ

転載: blog.csdn.net/weixin_45091053/article/details/127782958