您的位置:首页 > 数据库

SQL Server 2008下日志清理方法

2015-08-11 21:00 477 查看
1.将数据库设置成 简单 模式

选择要收缩的数据库,点右键 属性->选项,选择 简单模式



2.选择任务->收缩->文件



3.选择日志



或者用如下语句

代码

USE [master]

GO

ALTER DATABASE DNName SET RECOVERY SIMPLE WITH NO_WAIT

GO

ALTER DATABASE DNName SET RECOVERY SIMPLE

GO

USE DNName

GO

DBCC SHRINKFILE (N'LogFileName' , 0,TRUNCATEONLY)

GO

USE [master]

GO

ALTER DATABASE DNName SET RECOVERY FULL WITH NO_WAIT

GO

ALTER DATABASE DNName SET RECOVERY FULL

GO

SQL Server 2000要清理日志使用的是dump语句,但是在SQL Server2008里,这个语句不管用了,如果日志文件很大,比如超过1G,就需要截断一下日志文件以加快sqlserver的运行速度,在SQL Server2008里,方法改为:

有数据库 xxdb 在 SQL Server 2008 下,日志文件已经超过1G。

以往使用BACKUP语句-BACKUP LOG xxdb WITH NO_LOG 已经失效,在查阅 MSDN 之后发现 MS 提供的标准截断日志语句已经变为了 “BACKUP LOG 语句不指定 WITH COPY_ONLY”

使用语句 BACKUP LOG xxdb to disk='x:\work\1.bak' 成功将日志文件备份,并截断日志文件。这里x:代表你想要备份文件的盘符。

然后使用 DBCC SHRINKFILE (xxdb_log,10) 收缩日志文件到 10M

总结:

完整的收缩日志文件的 T-SQL 语句:

BACKUP LOG xxdb to disk='x:\work\1.bak'

DBCC SHRINKFILE (xxdb_log,10)

GO

--

BACKUP LOG <db_name> to disk=<'backupfilename'>

DBCC SHRINKFILE (<log_filename>,10)

GO

里面的x:\work是随意设置的。当然也可以收缩到比如5M或1M。

在用的:

USE[master]

GO

ALTERDATABASEYHDBSETRECOVERYSIMPLEWITHNO_WAIT

GO

ALTERDATABASEYHDBSETRECOVERYSIMPLE--简单模式

GO

USEYHDB

GO

DBCCSHRINKFILE(N'YHDB_log', 11,TRUNCATEONLY)

GO

USE[master]

GO

ALTERDATABASEYHDBSETRECOVERYFULLWITHNO_WAIT

GO

ALTERDATABASEYHDBSETRECOVERYFULL--还原为完全模式

GO
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: