发表于 2018-10-22 11:22:38

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

  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.日志截断后建议立即做一次完整备份

页: [1]
查看完整版本: 如何截断SQL Server2008+事务日志空间