一次性压缩Sqlserver2005中所有库日志的存储过程

2023年 4月 17日 35.5k 0

有没有办法更快一点? 有没有办法一次性收缩所有数据库? 复制代码 代码如下: alter database 数据库名 set recovery simple go dbcc shrinkdatabase (数据库名) go alter database 数据库名 set recovery ful

有没有办法更快一点? 有没有办法一次性收缩所有数据库? 复制代码 代码如下: alter database 数据库名 set recovery simple go dbcc shrinkdatabase (数据库名) go alter database 数据库名 set recovery full go 目前也有压缩日志的工具,一个B/S界面形式的操作压缩数据库的,就是在选择数据库的时候老需要重新去选择具体的库,而且数据库数量很大的时候,有些库被压缩了,并没有自动排序; 目前需要的是被压缩后的数据库自动滚到最后面,每次下拉列表中打开的始终是日志记录容量最大的那个库,这个容易实现,要求就是执行日志压缩的时候,执行速度要快些? 如何优化?有没有办法一次性压缩所有的库? 通过存储过程实现,一次性压缩所有数据库:在Sqlserver2005中测试通过 复制代码 代码如下: 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 //执行

相关文章

Oracle如何使用授予和撤销权限的语法和示例
Awesome Project: 探索 MatrixOrigin 云原生分布式数据库
下载丨66页PDF,云和恩墨技术通讯(2024年7月刊)
社区版oceanbase安装
Oracle 导出CSV工具-sqluldr2
ETL数据集成丨快速将MySQL数据迁移至Doris数据库

发布评论