DECLARE cur CURSOR FOR
SELECT
[object_n
ame]=s.name+'.'+OBJECT_NAME(A.object_id),
B.name
From Sys.dm_db_index_phys
ical_
stats(DB_ID('AdventureWorks'),NULL,null,null,null) AS A
JOIN sys.indexes AS B
ON A.[object_id]=B.[object_id]
AND A.[index_id]=B.[index_id]
JOIN sys.objects AS o
ON A.[object_id]=o.[object_id]
JOIN sys.schemas AS s
ON o.[schema_id]=s.[schema_id]
WHERE A.[index_id]>0
AND NOT EXISTS(
SELECT *
F
rom sys.
XMl_indexes
WHERE A.[object_id]=[object_id]
AND A.[index_id]=[index_id]
);
O
PEN cur;
DECLARE @objname v
Archar(128),@indname
VARchar(128);
DECLARE @
SQL nvarchar(4000);
FETCH NEXT FROM cur INTO @objname,@indname;
--重整所有索引,在这里先不管索引的碎片程度
WHILE @@FETCH_STATUS=0
BE
gin SET @sql='ALTER INDEX '+@indname+' ON '+@objname+' REBUILD';
EXEC(@sql);
FETCH NEXT FROM cur INTO @objname,@indname;
END
CLOSE cur;
DEALLOCATE cur;