• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

sqlserver一次压缩所有数据库日志方法

mysql 搞代码 4年前 (2022-01-09) 16次浏览 已收录 0个评论

本文章介绍了关于sqlserver一次压缩所有数据库日志方法,如果你想一次性把数据库中的所有数据库日志压缩可以参考本文章哈。

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

代码如下复制代码

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

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 getDataBaseCu本文来源gao($daima.com搞@代@#码(网rsor //释放
sp_helpdb urltest //比对数据库大小
exec shrinkDatabase //执行


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:sqlserver一次压缩所有数据库日志方法

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址