程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> SqlServer數據庫 >> 關於SqlServer >> 教你如何縮小SQL Server數據庫日志文件

教你如何縮小SQL Server數據庫日志文件

編輯:關於SqlServer

問題:數據庫實際大小為600MB, 日志文件實際大小為33MB, 但日志文件占用空間為2.8GB!試了多種方式,SHIRNK DATABASE, TRUNCATE LOG FILE, 都沒辦法將文件縮小。無論如何,這應該算SQL Server的一個BUG吧。

解決方法

後來找到下面的代碼,就可以將日志文件縮小到自己想要的大小了。把代碼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 < 
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved