日期:2011-01-25 23:11:00 来源:本站整理
sql server日记文件过大的办理办法[MSSQL防范]
本文“sql server日记文件过大的办理办法[MSSQL防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
sql server日记文件占磁盘空间过大的问题一向困扰着我们,下面就将教您一个办法,减小sql server日记文件,但愿对您有所启迪.
前几天也碰到sql server日记文件过大的问题,数据库实际大小为600M, 日记文件实际大小为33M, 但日记文件占用空间为2.8G!!!
试了多种方法,SHIRNK DATABASE, TRUNCATE LOG FILE, 都没办法将文件缩小.无论若何,这应当算SQL SERVER的一个BUG吧.
后来找到下面的代码,便可以将sql server日记文件缩小到自己想要的大小了.把代码COPY到查询解析器里,,然后改正此中的3个参数(数据库名,日记文件名,和目标日记文件的大小),运行便可(我已经用过多次了)
<
- -----
- SET NOCOUNT ON
- DECLARE @LogicalFileName sysname,
- @MaxMinutes INT,
- @NewSize INT
- USE Marias -- 要操作的数据库名
- 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 DummyTrans
- (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 necessary.
- 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
- INSERT DummyTrans VALUES ('Fill Log')
- DELETE DummyTrans
- 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 DummyTrans
- SET NOCOUNT OFF
以上是“sql server日记文件过大的办理办法[MSSQL防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |
评论内容只代表网友观点,与本站立场无关!
评论摘要(共 0 条,得分 0 分,平均 0 分)
查看完整评论