SQL数据库事务日志记录数据库的任何更改,用户可回滚事务日志来恢复数据,但随着数据库使用时间变长,日志文件也会变得很大。
若要避免数据库的事务日志被填满,例行备份至关重要。做了日志备份后,会释放不活跃的VLF,增加日志的可用空间。但默认情况下备份日志,其日志文件的大小并未变化,如下图
备份前,总大小24.13MB
备份后,总大小仍然为24.13MB,但已用空间占比从93.1%降至11.0%
也就是,已使用日志空间是减小了,但未使用日志空间并未释放。其实,如果磁盘空间足够的话,可以不用收缩空间
那如果需要释放空间以节约磁盘空间,怎么解决?
如果要收缩数据库日志大小,则需要截断事务日志
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
下面是测试环境的效果图
截断前
截断后
说明:
1.以上操作也可以通过图形界面来完成;
2.如何判断收缩后大小,可以通过下列命令查看
DBCC Sqlperf(Logspace)
3.日志截断后建议立即做一次完整备份
时间: 2024-10-29 14:13:08