码迷,mamicode.com
首页 > 数据库 > 详细

SQL Server 2008 收缩日志

时间:2014-10-09 20:29:08      阅读:216      评论:0      收藏:0      [点我收藏+]

标签:收缩日志

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
----

SQL Server 2008 收缩日志

标签:收缩日志

原文地址:http://gldbhome.blog.51cto.com/1552935/1561800

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!