SQL Server 一次性压缩Sqlserver2005中所有库日志的存储过程
2022-11-12 09:50:41
内容摘要
这篇文章主要为大家详细介绍了SQL Server 一次性压缩Sqlserver2005中所有库日志的存储过程,具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术笔
文章正文
这篇文章主要为大家详细介绍了SQL Server 一次性压缩Sqlserver2005中所有库日志的存储过程,具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术笔记!
有没有办法更快一点?有没有办法一次性收缩所有数据库?代码如下:
1 2 3 4 5 6 7 8 9 10 | <code> alter database 数据库名 set recovery simple go dbcc shrinkdatabase (数据库名) go alter database 数据库名 set recovery full go </code> |
代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | <code> create procedure shrinkDatabase as declare @name nvarchar(2000) declare getDataBaseCursor cursor for select name from sysdatabases //取出所有库名 open getDataBaseCursor fetch next from getDataBaseCursor into @name //将取出来的值放在一个变量中 while @@fetch_status=0 //根据值循环执行压缩 begin exec ( 'alter database ' + @name+ ' set recovery simple' ) exec ( 'dbcc shrinkdatabase(' +@name+ ')' ) exec ( 'alter database' +@name+ ' set recovery full' ) fetch next from getDataBaseCursor into @name end close getDataBaseCursor //关闭 deallocate getDataBaseCursor //释放 sp_helpdb urltest //比对数据库大小 exec shrinkDatabase //执行 </code> |
注:关于SQL Server 一次性压缩Sqlserver2005中所有库日志的存储过程的内容就先介绍到这里,更多相关文章的可以留意
代码注释