有没有办法更快一点?
有没有办法一次性收缩所有数据库?
复制代码 代码如下:
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 //执行

更多相关文章

  1. Android(安卓)Studio 修改 Logcat 颜色
  2. 理解Android中垃圾回收日志信息
  3. Android(安卓)sd卡log日志
  4. anr日志
  5. android单元测试用例和日志输出
  6. android学习日志六
  7. Android上的log,日志相关
  8. Android保存日志记录到sd卡的文件中
  9. Android(安卓)logcat详细用法

随机推荐

  1. MYSQL5.7源码包编译安装
  2. 具有多个调用的常规查询与使用PHP处理的
  3. 是否有人将数据库数据存储在PHP $ _SESSI
  4. mysql分组后取各组前五条
  5. MYSQL社区版安装手册
  6. 有没有办法确定是由Web应用程序(php进程)执
  7. mysql客户端工具使用
  8. PHP Array - 保存到MySQL时的奇数数据
  9. mysql 触发器 自动补全字段
  10. MySql-cluster中NDBD进程占用内存能否通