本文章介绍了关于sqlserver一次压缩所有数据库日志方法,如果你想一次性把数据库中的所有数据库日志压缩可以参考本文章哈。
有没有办法更快一点?
有没有办法一次性收缩所有?
代码如下 | 复制代码 |
alter database 数据库名 go dbcc shrinkdatabase (数据库名) alter database 数据库名 go |
目前也有压缩日志的工具,一个B/S界面形式的操作压缩数据库的,就是在选择数据库的时候老需要重新去选择具体的库,而且数据库数量很大的时候,有些库被压缩了,并没有自动排序; 目前需要的是被压缩后的数据库自动滚到最后面,每次下拉列表中打开的始终是日志记录容量最大的那个库,这个容易实现,要求就是执行日志压缩的时候,执行速度要快些?
如何优化?有没有办法一次性压缩所有的库?
通过存储过程实现,一次性压缩所有数据库:在Sqlserver2005中测试通过
代码如下 | 复制代码 |
create procedure shrinkDatabase as declare getDataBaseCursor cursor for name from sysdatabases //取出所有库名 open getDataBaseCursor fetch next from getDataBaseCursor while @@fetch_status=0 //根据值循环执行压缩 begin exec ('dbcc shrinkdatabase('+@name+')') exec ('alter database'+@name+' set recovery full') fetch next from getDataBaseCursor close getDataBaseCursor //关闭 |
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号