SQL Server 2008删除或压缩数据库日志的方法

by shinichi_wtn 2010-09-20 20:15

由于数据库日志增长被设置为“无限制”,所以时间一长日志文件必然会很大,一个400G的数据库居然有600G的LOG文件,严重占用了磁盘空间。由于主要是做OLAP,所以数据库本身不会有大变动,所以日志也就没有多少作用了,因此想办法把数据库日志文件收缩到很小或者删除。

网上搜索相关解决方案后,得到的答案丰富多彩,但是真正管用的方案并不多,这里分享一个csdn上找到的方法。这个方法讲述了SQL Server 2005和SQL Server 2008在收缩数据库日志的不同之处,颇有帮助。同时,该方法的效率很高,收缩600G的日志到10M只花了不到30秒。

下面一张图是收缩后的成果:

最后附上代码:

适用于SQL Server 2005的方法

Backup Log DNName WITH no_log
GO
DUMP TRANSACTION DNName WITH no_log
GO
USE DNName 
DBCC SHRINKFILE (2)
GO

说明:由于SQL Server 2008对文件和日志管理进行了优化,所以以上语句在SQL2005中可以运行但在SQL2008中已经被取消。

------------------------------

适用于SQL Server 2008的方法

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

说明:优点:此清除日志所运行消耗的时间短。缺点:不过此动作最好不要经常使用,因为它的运行会带来系统碎片。普通状态下LOG和DIFF的备份即可截断日志。此语句使用的恰当环境:当系统的日志文件异常增大或者备份LOG时间太长可能影响生产的情况下使用。

查看该方法的原始出处可以点击这里

Comments (1) -

lzhgigi People's Republic of China
8/1/2011 3:13:26 PM #

顶!!!!

Reply

(仅用于Gavatar)

  Country flag

biuquote
  • Comment
  • Preview
Loading

About

shinichi_wtnI'm Shinichi_wtn

程序员@Microsoft

[More...]

Recent Tweets

Twitter March 29, 22:31
北京不少公园已经陆续开始开放了,周六天气不错,去了趟野鸭湖湿地公园,人不少,风大了点,上一次去还是去年夏天 https://t.co/UZqlMtRAV1

Twitter March 16, 21:33
最近美股太惨烈了,今天开盘又熔断了😭 https://t.co/dNwwMZ58Yq

Twitter March 14, 23:47
火锅&寿喜锅 https://t.co/qqO0S4r40J

Twitter March 7, 21:31
在家待了太久了,出门透个气,没想到一路上车还不少,看来大家都想透气 https://t.co/IVmiKzdIA6

Twitter February 29, 15:58
RT @BillGates: COVID-19 could be a once-in-a-century pandemic, but the good news is that there are steps we can take now to slow its impact…

Twitter February 29, 15:57
☹️ https://t.co/YUMGlqJ7PZ

Twitter February 22, 18:40
已经在家办公3周了,希望疫情早日结束,回归正常 https://t.co/euvxHg8A72

Twitter January 25, 13:32
Happy Chinese New Year😃


Follow me on twitter >>

Month List