繁体中文
设为首页
加入收藏
当前位置:网络编程首页 >> Mssql >> 也谈如何缩小SQL SERVER日志文件

也谈如何缩小SQL SERVER日志文件

2007-10-15 13:26:00  作者:  来源:  浏览次数:296  文字大小:【】【】【

前几天也碰到日志文件过大的问题,数据库实际大小为600M, 日志文件实际大小为33M, 但日志文件占用空间为2.8G!

试了多种方式,SHIRNK DATABASE, TRUNCATE LOG FILE, 都没办法将文件缩小。无论如何,这应该算SQL Server的一个BUG吧。

后来找到下面的代码,就可以将日志文件缩小到自己想要的大小了。把代码COPY到查询分析器里,,然后修改其中的3个参数(数据库名,日志文件名,和目标日志文件的大小),运行即可(我已经用过多次了)


-----
SET NOCOUNT ON
DECLARE @LogicalFileName sy ame,
  @MaxMinutes INT,
  @NewSize INT


USE  Maria  -- 要操作的数据库名
SELECT  @LogicalFileName = 'Marias_log',  -- 日志文件名
@MaxMinutes = 10,  -- Limit on time allowed to wrap log.
  @NewSize = 100  -- 你想设定的日志文件的大小(M)

-- Setup / initialize
DECLARE @OriginalSize int
SELECT @OriginalSize = size
  FROM sysfiles
  WHERE name = @LogicalFileName
SELECT 'Original Size of ' + db_name() + ' LOG is ' +
  CONVERT(VARCHAR(30),@OriginalSize) + ' 8K pages or ' +
  CONVERT(VARCHAR(30),(@OriginalSize*8/1024)) + 'MB'
  FROM sysfiles
  WHERE name = @LogicalFileName
CREATE TABLE DummyTra 
  (DummyColumn char (8000) not null)


DECLARE @Counter  INT,
  @StartTime DATETIME,
  @TruncLog  VARCHAR(255)
SELECT  @StartTime = GETDATE(),
  @TruncLog = 'BACKUP LOG ' + db_name() + ' WITH TRUNCATE_ONLY'

DBCC SHRINKFILE (@LogicalFileName, @NewSize)
EXEC (@TruncLog)
-- Wrap the log if nece ary.
WHILE  @MaxMinutes > DATEDIFF (mi, @StartTime, GETDATE()) -- time has not expired
  AND @OriginalSize = (SELECT size FROM sysfiles WHERE name = @LogicalFileName) 
  AND (@OriginalSize * 8 /1024) > @NewSize 
  BEGIN -- Outer loop.
  SELECT @Counter = 0
  WHILE  ((@Counter < @OriginalSize / 16) AND (@Counter < 50000))
  BEGIN -- update
  I ERT DummyTra  VALUES ('Fill Log') 
  DELETE DummyTra 
  SELECT @Counter = @Counter + 1
  END 
  EXEC (@TruncLog) 
  END 
SELECT 'Final Size of ' + db_name() + ' LOG is ' +
  CONVERT(VARCHAR(30),size) + ' 8K pages or ' +
  CONVERT(VARCHAR(30),(size*8/1024)) + 'MB'
  FROM sysfiles
  WHERE name = @LogicalFileName
DROP TABLE DummyTra 
SET NOCOUNT OFF

责任编辑:


相关文章
 

最新文章

更多

· 巧用一条SQL 实现其它进...
· 解析:在SQL Server下数...
· 轻松掌握什么是层次型 基...
· 细化解析:SQL Server 2...
· 轻松掌握向外扩展数据库...
· 解析:正确的理解四类数...
· 处理SQL Server 2000的命...
· 轻松接触SQL Server 200...
· 细化解析:处理 SQL Ser...
· 教你轻松掌握怎样 创建新...

推荐文章

更多

· 巧用一条SQL 实现其它进...
· 解析:在SQL Server下数...
· 轻松掌握什么是层次型 基...
· 细化解析:SQL Server 2...
· 轻松掌握向外扩展数据库...
· 解析:正确的理解四类数...
· 处理SQL Server 2000的命...
· 轻松接触SQL Server 200...
· 细化解析:处理 SQL Ser...
· 教你轻松掌握怎样 创建新...

热点文章

更多