ck1987 发表于 2018-10-15 07:32:24

SQL Server 2008 收缩日志

  SQL SERVER 2008 中 BACKUP LOG WITH TRUNCATE_ONLY 已不再被支持,要收缩数据库日志,首先需要通过将数据库恢复模式设置为 SIMPLE 来截断该文件。
  语句如下:
  USE DATABASENAME;
  GO
  -- Truncate the log by changing the database recovery model to SIMPLE.
  ALTER DATABASE DATABASENAME SET RECOVERY SIMPLE;
  GO
  -- Shrink the truncated log file to 1 MB.
  DBCC SHRINKFILE (DATABASENAME_Log, 1);
  GO
  -- Reset the database recovery model.
  ALTER DATABASE DATABASENAME SET RECOVERY FULL;
  GO
  也可以通过图形界面来完成。
  通过先备份日志,然后再收缩日志文件,如下:
  back database mydb to disk='mydb_bak';
  dbcc shinkfile(mydb_log,10);--收缩至10m
  报错:
  [Cause: com.microsoft.sqlserver.jdbc.SQLServerException: 数据库 'riskDB' 的事务日志已满。若要查明无法重用日志中的空间的原因,
  请参阅 sys.databases 中的 log_reuse_wait_desc 列。]
  select name,log_reuse_wait_desc from sys.databases
  ----发现结果中对应到这个数据库的log_reuse_wait_desc为REPLICATION表示日志文件不能被压缩是因为replication
  alter database riskDB set recovery simple
  use riskDB
  dbcc shrinkfile('riskDB_log',10)
  alter database riskDB set recovery full
  ----

页: [1]
查看完整版本: SQL Server 2008 收缩日志