今天发现WEB空间提供的SQL Server2008数据库的日志已经达到规定的上限。
于是,准备把数据库的日志进行截断操作。
但是在操作过程中遇到一系列的问题。
经过查询试验,最后问题终于得到解决。
下面把操作的过程记录到下面:
像以前那样使用下面的语句对其截断:
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
使用以上方式,终于实现了截断数据库日志截断的操作。
新闻热点
疑难解答