首页 > 数据库技术 > 详细

游标的使用之压缩数据库Log文件

时间:2015-09-10 13:06:43      阅读:294      评论:0      收藏:0      [点我收藏+]

declare @databasename nvarchar(100)
--定义游标以及赋值 获取所有Online的Database Name
declare getDataBaseCursor  cursor for select name from  master.sys.databases where state_desc=‘online‘
--在使用游标之前必须打开它,打开游标
open getDataBaseCursor
--使用fetcth语句取得数据,一条FETCH语句一次可以将一条记录放入指定的变量中,达到Shrink每个DB的效果
fetch next from getDataBaseCursor into @databasename
while @@FETCH_STATUS = 0
begin
 declare @RecoveryModel nvarchar(20)
 declare @sql nvarchar(100)
 declare @logfileid int
 select @RecoveryModel= cast(DATABASEPROPERTYEX(name,‘RECOVERY‘) as varchar(20)) from master..sysdatabases where name =@databasename
 IF @RecoveryModel<>‘SIMPLE‘
  begin
                EXEC (‘ALTER DATABASE ‘+@databasename +‘ SET RECOVERY SIMPLE‘)
 end
 declare @dsql nvarchar(200)
 set @dsql=N‘select @logfileid = file_id from ‘ + @databasename+ N‘.sys.database_files where type_desc = ‘‘LOG‘‘‘
 exec sp_executesql @dsql,N‘@logfileid int output‘,@logfileid output
 EXEC(‘use ‘+@databasename+ ‘ DBCC SHRINKFILE( ‘+@logfileid+‘)‘)
fetch next from getDataBaseCursor into @databasename
end
--在游标操作的最后请不要忘记关闭游标,以使系统释放游标占用的资源
CLOSE getDataBaseCursor
--删除游标
DEALLOCATE getDataBaseCursor

游标的使用之压缩数据库Log文件

原文:http://www.cnblogs.com/tutuyforever/p/4797146.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!