mysql rebuild index_MSSQL Rebuild(重建)索引

前的项目是做数据库的归档,在每次archive后都需要对原数据库的索引进行rebuild,以减少索引碎片,于是乎就自己写了一段sql:

DECLARE @tablename VARCHAR(50)

DECLARE @indexname VARCHAR(50)

DECLARE @cmdsql NVARCHAR(MAX)

DECLARE index_cursor CURSOR

FOR

SELECT  OBJECT_NAME(object_id) AS Table_Name ,

name

FROM    sys.indexes

WHERE   name IS NOT NULL

AND OBJECT_NAME(object_id) IN ( SELECT  name

FROM    sys.tables )

OPEN index_cursor

FETCH NEXT FROM index_cursor

INTO @tablename,@indexname

WHILE @@FETCH_STATUS = 0

BEGIN

SET @cmdsql ='ALTER INDEX ['+@indexname+'] ON [dbo].['+@tablename+'] REBUILD WITH ( PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON, SORT_IN_TEMPDB = OFF, ONLINE = OFF )'

EXECUTE sp_executesql @cmdsql

PRINT @cmdsql

FETCH NEXT FROM index_cursor

INTO @tablename,@indexname

END

CLOSE index_cursor

DEALLOCATE index_cursor

希望对大家有帮助!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值