如何截断SQL Server2008+事务日志空间

SQL数据库事务日志记录数据库的任何更改,用户可回滚事务日志来恢复数据,但随着数据库使用时间变长,日志文件也会变得很大。

若要避免数据库的事务日志被填满,例行备份至关重要。做了日志备份后,会释放不活跃的VLF,增加日志的可用空间。但默认情况下备份日志,其日志文件的大小并未变化,如下图

备份前,总大小24.13MB

clip_image002

备份后,总大小仍然为24.13MB,但已用空间占比从93.1%降至11.0%

clip_image004

也就是,已使用日志空间是减小了,但未使用日志空间并未释放。其实,如果磁盘空间足够的话,可以不用收缩空间

 

那如果需要释放空间以节约磁盘空间,怎么解决?

 

如果要收缩数据库日志大小,则需要截断事务日志

SQL SERVER 2008 +环境下不再支持以下命令(SQL 2005下可用)

BACKUP LOG 数据库名 WITH TRUNCATE_ONLY 或

BACKUP LOG 数据库名 WITH NO_LOG

要收缩数据库日志,首先需要通过将数据库恢复模式设置为 Simple 来截断该文件。

USE DATABASENAME;

GO

ALTER DATABASE DATABASENAME SET RECOVERY SIMPLE; //更改数据库的恢复模式为简单

GO

DBCC SHRINKFILE (DATABASENAME_Log, 5);  //手工压缩日志文件至5MB

GO

ALTER DATABASE DATABASENAME SET RECOVERY FULL;  //将数据库的恢复模式改回来

GO

下面是测试环境的效果图

截断前

clip_image005

截断后

clip_image006

说明:

1.以上操作也可以通过图形界面来完成;

2.如何判断收缩后大小,可以通过下列命令查看

 DBCC Sqlperf(Logspace)

3.日志截断后建议立即做一次完整备份

你可能感兴趣的:(用户,如何,空间,日志记录,SQL数据库)