
DECLARE @sql nvarchar(500) |
|
DECLARE RebuildAllTableIndexes CURSOR |
READ_ONLY |
FOR |
SELECT QUOTENAME(SCHEMA_NAME(tbl.schema_id)) + '.' + QUOTENAME(tbl.NAME) tb_name, |
QUOTENAME(i.NAME) idx_name |
FROM sys.tables AS tbl |
INNER JOIN sys.indexes AS i ON ( |
i.index_id > 0 |
AND i.is_hypothetical = 0 |
) |
AND (i.object_id = tbl.object_id) |
|
DECLARE @tb_name nvarchar(255), @idx_name nvarchar(255) |
OPEN RebuildAllTableIndexes |
|
FETCH NEXT FROM RebuildAllTableIndexes INTO @tb_name, @idx_name |
WHILE (@@fetch_status <> -1) |
BEGIN |
IF (@@fetch_status <> -2) |
BEGIN |
SET @sql = N'ALTER INDEX ' + @idx_name + N' ON ' + @tb_name + N' REBUILD PARTITION = ALL WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, SORT_IN_TEMPDB = OFF, ONLINE = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON, FILLFACTOR = 90)' |
EXEC sp_executesql @sql |
END |
FETCH NEXT FROM RebuildAllTableIndexes INTO @tb_name, @idx_name |
END |
|
CLOSE RebuildAllTableIndexes |
DEALLOCATE RebuildAllTableIndexes |
GO |



