提问人:Aeden Maddok 提问时间:7/6/2022 更新时间:7/6/2022 访问量:749
数据库已完全恢复。RESTORE DATABASE 异常终止
The database is already fully recovered. RESTORE DATABASE is terminating abnormally
问:
我最近继承了 DBA 的职责,但没有接受过任何 DBA 培训。我们有一个数据库(出于安全原因省略了名称),该数据库基本上设置为在待机模式下运行,用作辅助系统的只读数据库。该数据库是通过我们供应商的日志传送更新的,因此我们基本上始终拥有其数据库的几乎最新副本。
然而,在周末,自动化过程开始在该过程的第 5 步失败。我们收到错误消息“数据库已完全恢复。[SQLSTATE 42000](错误 3153)RESTORE DATABASE 异常终止。[SQLSTATE 42000](错误 3013)。这一步失败了。
我需要帮助来了解失败的原因以及如何解决它。您能提供的任何帮助将不胜感激。下面是逐步分解的自动化作业的脚本。
/* Step 1 - Map Network Drive */
BEGIN
EXEC xp_cmdshell 'net use /persistent:no';
EXEC xp_cmdshell 'net use * /d /Y';
EXEC xp_cmdshell 'net use y: \\<FtpServer>\<folder> /user:<UserName> "<Password>"';
END
/* Step 2 - MOVE Files from network share to working folder */
BEGIN
EXEC xp_cmdshell 'if exist y:\*.trn move y:\*.trn y:\working';
END
/* Step 3 - Kill any exiting connections to the database */
BEGIN
USE [master];
DECLARE @kill varchar(8000) = '';
SELECT @kill = @kill + 'kill ' + CONVERT(varchar(5), session_id) + ';'
FROM sys.dm_exec_sessions
WHERE database_id = db_id('<DatabaseName>')
EXEC(@kill);
END
/* Step 4 - Restore Transaction Logs */
BEGIN
EXEC dbo.sp_DatabaseRestore
@Database = '<DatabaseName>',
@BackupPathFull = 'G:\Base Backup\TWHSQL2014FCluster$TWHSQL2014F_<DatabaseName>_FULL_20210305_213505\',
@BackupPathLog = 'y:\working\',
@RestoreDatabaseName = '<DatabaseName>',
@ContinueLogs = 1,
@RunRecovery = 0;
END
/* Step 5 - Change DB to STANDBY mode */
BEGIN
Restore Database [<DatabaseName>] With Standby = N'C:\Program Files\Microsoft SQL Server\MSSQL14.MSSQLSERVER\MSSQL\Backup\<DatabaseName>_RollBackUndo.bak'
END
/* Step 6 - MOVE Applied Logs to archive */
BEGIN
EXEC xp_cmdshell 'move y:\working\*.* y:\archived';
END
/* Step 7 - Archive Undo File */
BEGIN
EXEC xp_cmdshell 'if exist "C:\Program Files\Microsoft SQL Server\MSSQL14.MSSQLSERVER\MSSQL\Backup\*.bak" copy "C:\Program Files\Microsoft SQL Server\MSSQL14.MSSQLSERVER\MSSQL\Backup\*.bak" "G:\LogShipping Undo File" /y';
END
答:
0赞
Aeden Maddok
7/6/2022
#1
此问题已解决。问题的原因是日志文件没有得到恢复,但确实被移动到了存档文件夹,因此我们试图在恢复过程中跳过日志文件。尽管如此,我还是希望错误消息会指出类似于日志文件的内容没有正确的 LSN 值或其他内容来指示缺少日志。
评论