Сценарий курсора для резервного копирования файлов данных не выполняется при резервном копировании файлов журнала - PullRequest
0 голосов
/ 23 июня 2019

Я нашел здесь удобный скрипт, который позволяет мне создавать резервные копии всех несистемных баз данных с помощью курсора.Я нашел это здесь: https://solutioncenter.apexsql.com/create-daily-database-backups-with-unique-names-in-sql-server/

Я изменил только одну вещь в скрипте: Это успешно: SET @fileName = @path + @name + '_' + @dayname + '.BAK'
РЕЗЕРВНАЯ БАЗА ДАННЫХ @ name TO DISK = @fileName С NOFORMAT, INIT, SKIP, REWIND, NOUNLOAD, COMPRESSION, STATS = 10

Это создает резервную копию всех журналов, но после завершения задания сообщает о состоянии ошибки.SET @fileName = @path + @name + '_' + @dayname + '.TRN'
BACKUP LOG @name TO DISK = @fileName с NOFORMAT, INIT, SKIP, REWIND, NOUNLOAD, сжатием, STATS = 10

Я также удалил все параметры, но он не работает после завершения.

- полный сценарий с сайта выше приведен здесь.

- Сценарий 2. Резервное копирование всех несистемных баз данных

- 1.Объявление переменной

DECLARE @path VARCHAR(500)
DECLARE @name VARCHAR(500)
DECLARE @filename VARCHAR(256)
DECLARE @time DATETIME
DECLARE @year VARCHAR(4)
DECLARE @month VARCHAR(2)
DECLARE @day VARCHAR(2)
DECLARE @hour VARCHAR(2)
DECLARE @minute VARCHAR(2)
DECLARE @second VARCHAR(2)

- 2. Установка пути резервного копирования

SET @path = 'E:\Backup\'  

- 3. Получение значений времени

SELECT @time = GETDATE()
SELECT @year   = (SELECT CONVERT(VARCHAR(4), DATEPART(yy, @time)))
SELECT @month  = (SELECT CONVERT(VARCHAR(2), FORMAT(DATEPART(mm,@time),'00')))
SELECT @day    = (SELECT CONVERT(VARCHAR(2), FORMAT(DATEPART(dd,@time),'00')))
SELECT @hour   = (SELECT CONVERT(VARCHAR(2), FORMAT(DATEPART(hh,@time),'00')))
SELECT @minute = (SELECT CONVERT(VARCHAR(2), FORMAT(DATEPART(mi,@time),'00')))
SELECT @second = (SELECT CONVERT(VARCHAR(2), FORMAT(DATEPART(ss,@time),'00')))

- 4. Определениеоперации с курсором

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

- 5.Инициализация операций с курсором

OPEN db_cursor   
FETCH NEXT FROM db_cursor INTO @name   

WHILE @@FETCH_STATUS = 0   
BEGIN

- 6. Определение формата имени файла

   SET @fileName = @path + @name + '_' + @year + @month + @day + @hour + @minute + @second + '.BAK'  
   BACKUP DATABASE @name TO DISK = @fileName  


   FETCH NEXT FROM db_cursor INTO @name   
END   
CLOSE db_cursor   
DEALLOCATE db_cursor

Я изменил резервную копию базы данных с базы данных.Успех.Войти.Отказ после успеха.Вернуться к базе данных.Успех.

Несмотря на то, что с LOG успешно, в конце неудача делает для меня невозможным делать следующие шаги.

...