首页 > 数据库技术 > 详细

批量收缩数据库日志文件

时间:2014-06-24 23:25:50      阅读:447      评论:0      收藏:0      [点我收藏+]
declare @sql nvarchar(max),@paramDef nvarchar(100)
declare dbname scroll cursor for 
  select name,recovery_model from sys.databases where database_id>7
open dbname

declare @dbname varchar(50),@recovery_model int,@db_log_file varchar(100)
set @dbname=''
fetch first from dbname into @dbname,@recovery_model
while @@FETCH_STATUS=0
begin
  --alter recovery model
  if (@recovery_model<>3)
  begin
    set @sql=N' alter database '+@dbname+' set RECOVERY  SIMPLE '
    print 'Recovery :'+@sql
   exec sp_executesql @sql
  end
  --get log file of database
  set @sql=N'select @log_file=name from '+@dbname+'.sys.database_files where type=1'
  set @paramDef= N'@log_file varchar(100) OUTPUT '
  exec sp_executesql @sql,@paramDef,@log_file=@db_log_file output
  print @db_log_file 
  
  --shrink file
  set @sql= N'USE ['+@dbname+'] DBCC SHRINKFILE  ('+@db_log_file+')'
  exec sp_executesql @sql
  
  fetch next from dbname into @dbname,@recovery_model
end
close dbname
deallocate dbname


批量收缩数据库日志文件,布布扣,bubuko.com

批量收缩数据库日志文件

原文:http://blog.csdn.net/zhnglicho/article/details/33731775

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