清除SQL Server資料庫日誌
無論是開發、測試環境還是正式的生產環境,常常會由於SQL Server資料庫日誌已滿,導致無法Insert或update資料。此時需要清除資料庫日誌。
以下是清除SQL Server資料庫日誌的SQL指令碼:
SET NOCOUNT ON
DECLARE @LogicalFileName sysname,
@MaxMinutes INT,
@NewSize INT
USE DatabaseName -- 要操作的資料庫名
SELECT @LogicalFileName = 'YourDatabaseLogFileLogicName', -- 日誌檔名
@MaxMinutes = 10, -- Limit on time allowed to wrap log.
@NewSize = 1 -- 你想設定的日誌檔案的大小(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
說明:
粗斜體字標記的程式碼是你需要修改以適用於你的實際環境的。
[@more@]來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/13651903/viewspace-1013837/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- SQL Server 清除資料庫日誌指令碼SQLServer資料庫指令碼
- SQL Server資料庫日誌清除的兩個方法SQLServer資料庫
- SQL Server 檢視資料庫日誌SQLServer資料庫
- 清除SQL Server日誌的方法介紹SQLServer
- SQL Server 無日誌檔案附加資料庫SQLServer資料庫
- SQL Server無日誌資料庫恢復模式SQLServer資料庫模式
- 清除 SQL SERVER 2005 事務日誌SQLServer
- SQL SERVER日誌清除的兩種方法(轉)SQLServer
- SQL Server資料庫事務日誌儲存序列SQLServer資料庫
- SQL server資料庫高可用日誌傳送的方法SQLServer資料庫
- Sql Server2014資料庫清理日誌SQLServer資料庫
- SQLServer資料庫日誌清理 清除sqlserver2005日誌SQLServer資料庫
- SQL Server 2005無日誌檔案附加資料庫SQLServer資料庫
- SQL Server資料庫事務日誌序列號(LSN)介紹SQLServer資料庫
- 使用fn_dblog解析SQL SERVER 資料庫日誌方法SQLServer資料庫
- SQL SERVER 資料庫日誌收縮整理 三種方法軼事分離資料庫而是清空日誌三是截斷日誌SQLServer資料庫
- SQL Server 2005資料庫日誌丟失的恢復SQLServer資料庫
- 查詢SQL Server 2005資料庫重做日誌的資訊SQLServer資料庫
- 用sql語句dbcc log 檢視SQL Server 資料庫的事務日誌SQLServer資料庫
- rman清除歸檔日誌經典資料
- SQL Server 收縮日誌SQLServer
- SQL Server 錯誤日誌SQLServer
- Sql server日誌損壞後的資料恢復(轉)SQLServer資料恢復
- 清除SqlServer日誌SQLServer
- SQL Server 日誌傳送配置SQLServer
- SQL Server 2008在資料庫損壞時備份事務日誌SQLServer資料庫
- SQL Server資料庫安全SQLServer資料庫
- SQL Server 資料庫映象SQLServer資料庫
- SQL Server 資料庫索引SQLServer資料庫索引
- 資料庫映象 (SQL Server)資料庫SQLServer
- SQL Server 事務日誌傳輸SQLServer
- sql server日誌不能shrink或truncateSQLServer
- SQL Server事務日誌介紹SQLServer
- 壓縮SQL SERVER日誌程式碼SQLServer
- SQL Server重做日誌管理機制SQLServer
- SQL Server ErrorLog 錯誤日誌SQLServerError
- sql2005,sql2008清除日誌SQL
- SQL Server收縮資料庫SQLServer資料庫