请教SQL Server2008数据库清除日志的问题

HarleyTung 2009-07-25 11:11:50
我之前执行
DBCC SHRINKFILE ('MyDb_log',1)
DBCC SHRINKFILE (MyDb_log,10)

都有效,现在日志文件有27G 我再执行这两句就无效了,于是我就到 数据库->任务->收缩->数据库和文件 都无效,执行完日志文件还是27G 请问大家怎么办?
...全文
6391 15 打赏 收藏 转发到动态 举报
写回复
用AI写文章
15 条回复
切换为时间正序
请发表友善的回复…
发表回复
mazhipeng888 2012-03-04
  • 打赏
  • 举报
回复

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'DNName_Log' , 11, TRUNCATEONLY)
GO
USE [master]
GO

ALTER DATABASE DNName SET RECOVERY FULL WITH NO_WAIT

GO

ALTER DATABASE DNName SET RECOVERY FULL --还原为完全模式

GO

  • 打赏
  • 举报
回复
先手动备份事务日志,然后再收缩日志即可。
zqh139 2010-01-05
  • 打赏
  • 举报
回复
支持一下,如果手动去做也是可以吧!
Zoezs 2009-07-26
  • 打赏
  • 举报
回复

SQL2008 的收缩日志
由于SQL2008对文件和日志管理进行了优化,所以以下语句在SQL2005中可以运行但在SQL2008中已经被取消:
(SQL2005)
Backup Log DNName with no_log
go
dump transaction DNName with no_log
go
USE DNName
DBCC SHRINKFILE (2)
Go
--------------------------------------------------------------
(SQL2008):
在SQL2008中清除日志就必须在简单模式下进行,等清除动作完毕再调回到完全模式。
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'DNName_Log' , 11, TRUNCATEONLY)
GO
USE [master]
GO

ALTER DATABASE DNName SET RECOVERY FULL WITH NO_WAIT

GO

ALTER DATABASE DNName SET RECOVERY FULL --还原为完全模式

GO

优点:此清除日志所运行消耗的时间短,90GB的日志在分钟左右即可清除完毕,做完之后做个完全备份在分钟内
即可完成。
缺点: 不过此动作最好不要经常使用,因为它的运行会带来系统碎片。普通状态下LOG和DIFF的备份即可截断日志。
此语句使用的恰当环境:当系统的日志文件异常增大或者备份LOG时间太长可能影响生产的情况下使用。
lao_bulls 2009-07-26
  • 打赏
  • 举报
回复
mark
HarleyTung 2009-07-25
  • 打赏
  • 举报
回复
是的,那句没用了。现在执行
BACKUP LOG MyDb to disk='MyDb'
DBCC SHRINKFILE ('MyDb_log',1)
可以,但是要执行两次以上,日志才会变成1M
jinjazz 2009-07-25
  • 打赏
  • 举报
回复
http://msdn.microsoft.com/zh-cn/library/ms144262.aspx
果然没有了
jinjazz 2009-07-25
  • 打赏
  • 举报
回复
1.清空日志:DUMP TRANSACTION databasename WITH NO_LOG

2.截断事务日志:BACKUP LOG databasename WITH NO_LOG

3.收缩数据库:DBCC SHRINKDATABASE(databasename)
HarleyTung 2009-07-25
  • 打赏
  • 举报
回复
1.清空日志
DUMP TRANSACTION 库名 WITH NO_LOG

2.截断事务日志:
BACKUP LOG 库名 WITH NO_LOG

SQL Server 2008 不支持这两句,2005就可以
--小F-- 2009-07-25
  • 打赏
  • 举报
回复
1.清空日志
DUMP TRANSACTION 库名 WITH NO_LOG

2.截断事务日志:
BACKUP LOG 库名 WITH NO_LOG

3.收缩数据库文件(如果不压缩,数据库的文件不会减小
企业管理器--右键你要压缩的数据库--所有任务--收缩数据库--收缩文件
--选择日志文件--在收缩方式里选择收缩至XXM,这里会给出一个允许收缩到的最小M数,直接输入这个数,确定就可以了
--选择数据文件--在收缩方式里选择收缩至XXM,这里会给出一个允许收缩到的最小M数,直接输入这个数,确定就可以了
feixianxxx 2009-07-25
  • 打赏
  • 举报
回复
budong...
claro 2009-07-25
  • 打赏
  • 举报
回复
先完全备份,再截断日志,最后收缩等操作。
HarleyTung 2009-07-25
  • 打赏
  • 举报
回复
--清除日志
BACKUP LOG MyDb to disk='MyDb'
DBCC SHRINKFILE ('MyDb_log',1)

--备份清除日志
BACKUP LOG MyDb to disk='D:\database\MyDb.bak'
DBCC SHRINKFILE (MyDb_log,10)

我也这样了还是不行,要怎么截断呢?
jinjazz 2009-07-25
  • 打赏
  • 举报
回复
先截断日志再收缩

34,571

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧