|
本文详细介绍了几种解决sql server数据库日志不断增大的办法。
一: 分享]解决SQL日志增大的办法
--假设test2为数据库名称 在查询分析器中执行: backup log MuOnline with NO_LOG backup log MuOnline with TRUNCATE_ONLY DBCC SHRINKDATABASE(MuOnline)
将上面的语句多次执行,直到日志文件缩小。 exec sp_dboption 'MuOnline','autoshrink','on' 建立作业,每半个小时一次日志备份,每天一次完全数据库备份。 在Log收缩到正常大小后,将autoshrink选项设置为off。
二: 数据库增大是因为你的日志增大了,以前大家讨论过的,最简单可行的办法就是在你数据库属性->选项->故障还原里面选成简单模式(缺省为完全模式),然后选收缩数据库进行一次收缩,以后你的数据库基本就不怎么会增长了
三: 1、进入企业管理器,选中数据库,比如muonline 2、所有任务->分离数据库 3、到数据库文件的存放目录,将MuOnline_log.LDF文件删除,你怕S的话可以拷出去 4、企业管理器->附加数据库,选muonline,这个时候你会看见日志文件这项是一个叉,不要紧继续,此时数据库就会提示你该数据库无日志是否创建一个新的,确定就是了。 5、记得数据库重新附加后用户要重新设置一下。
SET NOCOUNT ON DECLARE @LogicalFileName sysname, @MaxMinutes INT, @NewSize INT
USE Muonline (你要操作的数据库名) SELECT @LogicalFileName = 'Muonline_log',(日志文件名) @MaxMinutes = 10,(设定每格多长时间写一次日志) @NewSize = 30(你想设定的日志文件的大小 单位: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
|