0

SQL 2012 では、次のクエリがあります。

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 = 'D:\BACKUP\'

-- ファイル名の形式を指定

SET @fileDate = CONVERT(VARCHAR(20),GETDATE(),112) 
--SELECT @fileDate = CONVERT(VARCHAR(20),GETDATE(),112) + REPLACE(CONVERT(VARCHAR(20),GETDATE(),108),':','')



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

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 --with differential
       FETCH NEXT FROM db_cursor INTO @name   
END   

CLOSE db_cursor   
DEALLOCATE db_cursor "

このクエリはデータベースのバックアップを作成しましたが、もう一度実行すると、新しいバックアップが同じファイルに配置されます。新しいバックアップを新しい .bak ファイルに配置するにはどうすればよいですか? ありがとう!!

4

3 に答える 3

0

使用しているので

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

これは、現在の日付の日付部分のみを取得することを意味します。時間と分を追加する形式を使用します。

SET @fileDate = REPLACE(REPLACE(CONVERT(VARCHAR(20),GETDATE(),126),":",""),"-","")
于 2013-09-23T11:25:13.190 に答える