当前位置:K88软件开发文章中心编程语言SQLSQL01 → 文章内容

SQL Server 2008中截断数据库日志的方法

减小字体 增大字体 作者:佚名  来源:翔宇亭IT乐园  发布时间:2019-1-3 1:48:59

:2014-03-14 19:43:44

今天发现数据库日志已经达到规定的上限,准备像以前那样使用下面的语句对其截断:

BACKUP LOG 数据库名称 WITH NO_LOG

结果给出以下错误:

消息 3032,级别 16,状态 2,第 10 行
此语句不支持一个或多个选项(no_log)。请查阅文档以了解所支持的选项。

接着又使用下面的语句:

DUMP TRANSACTION 数据库名称 WITH NO_LOG

提示以下信息:

消息 156,级别 15,状态 1,第 1 行
关键字 'TRANSACTION' 附近有语法错误。

然后又使用下面的方法:

backup log 数据库名称 with TRUNCATE_ONLY

提示:

消息 155,级别 15,状态 1,第 11 行
'TRUNCATE_ONL' 不是可以识别的 BACKUP 选项。

最后,在网上搜索了一下,发现以上方法在SQL Server 2008中不再受支持,随后看各种帖子,并通过试验,发现下面的方法是可行的:

第一步:
ALTER DATABASE 数据库名称 SET RECOVERY SIMPLE
GO

第二步:
   DBCC SHRINKFILE ('数据库日志逻辑名称' , 0, TRUNCATEONLY)
   GO

第三步:
  ALTER DATABASE 数据库名称 SET RECOVERY FULL
  GO


SQL Server 2008中截断数据库日志的方法