1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > 一次性压缩Sqlserver中所有库日志的存储过程

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

时间:2023-08-29 12:43:29

相关推荐

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

数据库|mysql教程

压缩,库日志

数据库-mysql教程

图片展示 asp 源码,修改ubuntu界面大小,tomcat 桌面图标,php爬虫 新闻,php数据值怎么判断,seo现在lzw

通过下面这个可以执行单个数据库日志压缩,问题每次都要写数据库名字,日志大的话执行速度没有那么快

asp图表统计源码,vscode html环境,ubuntu gfs,如何申请tomcat,安卓使用sqlite输出,微擎cms插件源码下载,web前端框架设计和交互,兖州哪里可以买爬虫药,php 修改图片,阿克苏网络推广seo,网站框架布局,上传图片网页源码,餐饮招商加盟网站模板lzw

简版导航网站源码,ubuntu 密码太简单,爬虫用哪种温控,isdigit php,合肥seo转化lzw

有没有办法更快一点?

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

代码如下:

alter database 数据库名

set recovery simple

go

dbcc shrinkdatabase (数据库名)

go

alter database 数据库名

set recovery full

go

目前也有压缩日志的工具,一个B/S界面形式的操作压缩数据库的,就是在选择数据库的时候老需要重新去选择具体的库,而且数据库数量很大的时候,有些库被压缩了,并没有自动排序; 目前需要的是被压缩后的数据库自动滚到最后面,每次下拉列表中打开的始终是日志记录容量最大的那个库,这个容易实现,要求就是执行日志压缩的时候,执行速度要快些?

如何优化?有没有办法一次性压缩所有的库?

通过存储过程实现,一次性压缩所有数据库:在Sqlserver中测试通过

代码如下:

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。