SQL语句实现SQL Server 2000及Sql Server 2005日志收缩(批量)
2022-11-12 09:54:12
内容摘要
这篇文章主要为大家详细介绍了SQL语句实现SQL Server 2000及Sql Server 2005日志收缩(批量),具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术笔
文章正文
这篇文章主要为大家详细介绍了SQL语句实现SQL Server 2000及Sql Server 2005日志收缩(批量),具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术笔记!
代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | <code>DECLARE @name VARCHAR(25) DECLARE @SQL VARCHAR(1000) DECLARE @logid INT DECLARE sysdatabase_name CURSOR FOR SELECT name FROM master.dbo.sysdatabases OPEN sysdatabase_name FETCH NEXT FROM sysdatabase_name INTO @name WHILE @@FETCH_STATUS = 0 BEGIN IF ( @name NOT IN ( 'xxx' )) --不需要进行日志收缩的数据库名 BEGIN SET @SQL =' DECLARE @logid INT USE ' + @name+' SELECT @logid = fileid FROM sysfiles WHERE RIGHT(rtrim(filename),3) = '' ldf '' BACKUP LOG ' + @name+' WITH NO_LOG DBCC SHRINKFILE (@logid) ' EXEC (@SQL) END FETCH NEXT FROM sysdatabase_name INTO @name END CLOSE sysdatabase_name DEALLOCATE sysdatabase_name </code> |
代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 | <code>-->Title:生成測試數據 -->Author:wufeng4552 --> Date :2009-09-15 08:56:03 declare @dbname nvarchar(20) --數據庫名稱 declare @sql nvarchar(max) declare sysdbname cursor for select name from master.dbo.sysdatabases open sysdbname fetch next from sysdbname into @dbname while @@fetch_status=0 begin if (@dbname not in( 'xxx' ))--不需要进行日志收缩的数据库名 begin set @sql=--日誌文件ID N ' declare @logid int ' + N ' use ' +@dbname+ N ' select @logid=fileid from sysfiles where right(ltrim(rtrim(filename)),3)=' 'ldf' '' + --截断事务日志 N ' backup log ' +@dbname+ ' with no_log ' + --收缩指定数据文件 N ' dbcc shrinkfile(@logid)' exec (@sql) end fetch next from sysdbname into @dbname end close sysdbname deallocate sysdbname </code> |
注:关于SQL语句实现SQL Server 2000及Sql Server 2005日志收缩(批量)的内容就先介绍到这里,更多相关文章的可以留意
代码注释