清理SQL Server 2008日志文件
SQL 2008日志文件占了23G硬盘空间,而事务日志已经截断(Truncate),实际日志内容很小,1G都不到,想要释放日志文件霸占的多余空间。 但是,无论怎么收缩(Shrink)日志文件,空间就是不能释放,总是出现错误: Cannot shrink log file 2 (CNBlogsText_log) bec
SQL 2008日志文件占了23G硬盘空间,而事务日志已经截断(Truncate),实际日志内容很小,1G都不到,想要释放日志文件霸占的多余空间。
但是,无论怎么收缩(Shrink)日志文件,,空间就是不能释放,总是出现错误:
Cannot shrink log file 2 (CNBlogsText_log) because of minimum log space required.
之前解决过类似的问题,也写过一篇博客-SQL Server 2008事务日志清理,当时采用的最终解决方法是:
将恢复模式由完整(Full)改为简单(Simple)
收缩(Shrink)日志文件
将恢复模式由简单(Simple)改为完整(Full)
一直以为这就是终极方法,但是竟然没能终结这次遇到的问题。
经过不懈的努力,终于找到真正的终极方法:
1. Detach数据库(Detach之前一定要屏蔽所有对这个数据库的写入操作)
2. 删除或重命名日志文件
3. Attach数据库,这时会提示找不到日志文件
4. 移除(Remove)这个找不到的日志文件,然后点击Ok进行Attach,SQL Server会在数据文件所在的文件夹自动创建一个新的日志文件完成Attach。
5. 如果日志文件需要存放在另外的路径,要再通过Detach/Attach进行日志文件的移动操作。
Detach数据库
将日志文件移动至新的位置
Attach数据库,修改日志文件的路径并完成Attach
该终极方法的弊端是在操作期间,被操作的数据库不能被正常访问。
上一篇: Makefile的基础知识
推荐阅读
-
SQL Server误区30日谈 第19天 Truncate表的操作不会被记录到日志
-
SQL Server误区30日谈 第14天 清除日志后会将相关的LSN填零初始化
-
SQL Server利用bcp命令把SQL语句结果生成文本文件
-
MSSQL 2005/2008 日志压缩清理方法小结
-
SQL SERVER数据库清空日志图文教程分享
-
VS2008连接SQL Server数据库文件出错的解决方法
-
c#操作sql server2008 的界面实例代码
-
没有SQL Server数据库时如何打开.MDF文件
-
SQL Server无日志恢复数据库(2种方法)
-
SQLServer日志清空语句(sql2000,sql2005,sql2008)