一次性压缩Sqlserver2005中所有库日志的存储过程
更新时间:2012年01月20日 22:14:11 作者:
通过下面这个可以执行单个数据库日志压缩,问题每次都要写数据库名字,日志大的话执行速度没有那么快
有没有办法更快一点?
有没有办法一次性收缩所有数据库?
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 //执行
有没有办法一次性收缩所有数据库?
复制代码 代码如下:
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 //执行
您可能感兴趣的文章:
- 使用sqlserver存储过程sp_send_dbmail发送邮件配置方法(图文)
- sqlserver2005利用临时表和@@RowCount提高分页查询存储过程性能示例分享
- sqlserver2008查看表记录或者修改存储过程出现目录名无效错误解决方法
- sqlserver 存储过程中If Else的用法实例
- .net下调用sqlserver存储过程的小例子
- SqlServer获取存储过程返回值的实例
- sqlserver 各种判断是否存在(表名、函数、存储过程等)
- sqlserver 存储过程带事务 拼接id 返回值
- SqlServer存储过程实现及拼接sql的注意点
- SQLServer存储过程中事务的使用方法
- 获取SqlServer存储过程定义的三种方法
相关文章
ASP.NET下向SQLServer2008导入文件实例操作方法
在Microsoft SQL Server2008以后的版本中,将删除image数据类型。在新的开发工作中将不适用此数据类型,并打算修改当前使用此数据类型的应用程序,改用varbinary(max)数据类型。2010-09-09
sql server 2016不能全部用到CPU的逻辑核心数的问题
服务器总共CPU核心有72核,但sql 只能用到40核心,想信也有很多人遇到这问题,那么今天这节就先说说这问题是怎么出现的2023-05-05
SQL Server 利用触发器对多表视图进行更新的实现方法
这篇文章主要介绍了SQL Server 利用触发器对多表视图进行更新的实现方法,需要的朋友可以参考下2016-10-10
通过T_sql语句向其中一次填入一条数据或一次填入多条数据的方式填充数据
使用T_sql语句向其中一次填入一条数据或一次填入多条数据的方式填入数据,需要的朋友可以参考下2012-10-10
sqlserver中通过osql/ocmd批处理批量执行sql文件的方法
上周在测试环境建了几十张表,保存了.sql文件,准备在正式环境重建的时候懒得一个个打开建了,做一在网上搜寻了一下,果然有简单点的方法。2011-08-08


最新评论