服务器之家

服务器之家 > 正文

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

时间:2019-12-13 11:41     来源/作者:MSSQL教程网

有没有办法更快一点? 
有没有办法一次性收缩所有数据库? 

复制代码代码如下:


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 //执行 

相关文章

热门资讯

玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分 2019-06-21
男生常说24816是什么意思?女生说13579是什么意思?
男生常说24816是什么意思?女生说13579是什么意思? 2019-09-17
配置IIS网站web服务器的安全策略配置解决方案
配置IIS网站web服务器的安全策略配置解决方案 2019-05-23
Nginx服务器究竟是怎么执行PHP项目
Nginx服务器究竟是怎么执行PHP项目 2019-05-24
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情 2019-06-22
返回顶部