加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

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

发布时间:2020-12-12 09:27:16 所属栏目:MsSql教程 来源:网络整理
导读:有没有办法更快一点? 有没有办法一次性收缩所有数据库? div class="codetitle" a style="CURSOR: pointer" data="90644" class="copybut" id="copybut90644" onclick="doCopy('code90644')" 代码如下:div class="codebody" id="code90644" alter database

有没有办法更快一点?
有没有办法一次性收缩所有数据库?
<div class="codetitle"><a style="CURSOR: pointer" data="90644" class="copybut" id="copybut90644" onclick="doCopy('code90644')"> 代码如下:<div class="codebody" id="code90644">
alter database 数据库名
set recovery simple
go
dbcc shrinkdatabase (数据库名)
go
alter database 数据库名
set recovery full
go

目前也有压缩日志的工具,一个B/S界面形式的操作压缩数据库的,就是在选择数据库的时候老需要重新去选择具体的库,而且数据库数量很大的时候,有些库被压缩了,并没有自动排序; 目前需要的是被压缩后的数据库自动滚到最后面,每次下拉列表中打开的始终是日志记录容量最大的那个库,这个容易实现,要求就是执行日志压缩的时候,执行速度要快些?
如何优化?有没有办法一次性压缩所有的库?
通过存储过程实现,一次性压缩所有数据库:在Sqlserver2005中测试通过
<div class="codetitle"><a style="CURSOR: pointer" data="82358" class="copybut" id="copybut82358" onclick="doCopy('code82358')"> 代码如下:<div class="codebody" id="code82358">
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 //执行

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读