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
什麼版本的SQL Server?如果是2005年或更高,爲什麼不使用維護計劃;有預定義的任務用於刪除舊文件和刪除維護歷史記錄。從TSQL執行文件操作最多是尷尬的。 – Pondlife 2011-04-20 10:53:57
非常感謝。我將使用維護計劃。 – Tomas 2011-04-20 10:57:44
@Pondlife - 你應該發表你的評論作爲答案。 – Lamak 2011-04-20 13:13:39