首 页IT知识库翔宇问吧收藏内容
当前位置:翔宇亭IT乐园IT知识库数据库SQL Server

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

减小字体 增大字体 作者:biye5u.com  来源:本站原创  发布时间:2014-03-14 19:43:44

今天发现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

使用以上方式,终于实现了截断数据库日志截断的操作。

微信搜索“优雅的代码”关注本站的公众号,或直接使用微信扫描下面二维码关注本站公众号,以获取最新内容。

个人成长离不开各位的关注,你的关注就是我继续前行的动力。

知识评论评论内容只代表网友观点,与本站立场无关!

   评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
愿您的精彩评论引起共鸣,带来思考和价值。
用户名: 查看更多评论
分 值:100分 90分 80分 70分 60分 40分 20分
内 容:
验证码:
关于本站 | 网站帮助 | 广告合作 | 网站声明 | 友情连接 | 网站地图
本站部分内容来自互联网,如有侵权,请来信告之,谢谢!
Copyright © 2007-2022 biye5u.com. All Rights Reserved.