2011-04-20 68 views
2

我使用SQL Server代理在下面運行T-SQL腳本來備份MSSQL服務器中的所有數據庫。我想通過添加選項從文件系統中刪除一個星期的舊數據庫備份來改進腳本。任何人都可以指出我如何使用T-SQL來做到這一點?如何使用T-SQL刪除一個星期的舊文件

DECLARE @name VARCHAR(50) -- database name 
DECLARE @path VARCHAR(256) -- path for backup files 
DECLARE @fileName VARCHAR(256) -- filename for backup 
DECLARE @fileDate VARCHAR(20) -- used for file name 

SET @path = 'C:\www\databases\Backup\' 

SELECT @fileDate = CONVERT(VARCHAR(20),GETDATE(),112) 

DECLARE db_cursor CURSOR FOR 
SELECT name 
FROM master.dbo.sysdatabases 
WHERE name NOT IN ('master','model','msdb','tempdb') 

OPEN db_cursor 
FETCH NEXT FROM db_cursor INTO @name 

WHILE @@FETCH_STATUS = 0 
BEGIN 
     SET @fileName = @path + @name + '_' + @fileDate + '.BAK' 
     BACKUP DATABASE @name TO DISK = @fileName 

     FETCH NEXT FROM db_cursor INTO @name 
END 

CLOSE db_cursor 
DEALLOCATE db_cursor 
+7

什麼版本的SQL Server?如果是2005年或更高,爲什麼不使用維護計劃;有預定義的任務用於刪除舊文件和刪除維護歷史記錄。從TSQL執行文件操作最多是尷尬的。 – Pondlife 2011-04-20 10:53:57

+0

非常感謝。我將使用維護計劃。 – Tomas 2011-04-20 10:57:44

+0

@Pondlife - 你應該發表你的評論作爲答案。 – Lamak 2011-04-20 13:13:39

回答

1

您也可以直接使用xp_delete_file(未記錄),這是維護計劃使用的。

This post有關於其使用的更多細節。

+0

這會在特定日期之前刪除文件。所以,如果你有任何你想要保存的數據庫備份,那麼你的SOL。 – QueueHammer 2013-08-29 15:41:10