文件还原(完整恢复模式)

适用于:SQL Server

本主题仅与在完整恢复模式或大容量加载恢复模式下包含多个文件或文件组的数据库相关。

文件还原的目标是还原一个或多个损坏的文件,而不是还原整个数据库。 文件还原方案由复制、前滚和恢复相应数据的单一还原顺序组成。

如果正在还原的文件组为读/写文件组,则在还原上一次数据备份或差异备份以后必须应用连续的日志备份链。 这样才会使文件组记录到日志文件的当前活动日志记录中。 恢复点通常靠近日志的末端,但并非总是如此。

如果正在还原的文件组为只读文件组,则通常不需要应用日志备份,并且会跳过该操作。 如果在文件变成只读后进行了备份,则该备份为要还原的最后备份。 前滚在目标点停止。

这些文件还原方案如下:

  • 脱机文件还原

    在“脱机文件还原” 中,还原已损坏的文件或文件组时,数据库处于脱机状态。 还原顺序结束时,数据库将联机。

    所有版本的 SQL Server 都支持脱机文件还原。

  • 联机文件还原

    在“联机文件还原” 中,如果数据库在还原时处于联机状态,则该数据库在文件还原过程中将保持联机状态。 不过,各文件组中如果有文件正在被还原,则该文件组在还原操作过程中将处于脱机状态。 恢复脱机文件组中的所有文件之后,该文件组将自动变为联机状态。

    有关联机页和文件还原支持的信息,请参阅“SQL Server 2022 的各个版本及其支持的功能”。 有关联机还原的详细信息,请参阅联机还原 (SQL Server)

    提示

    如果你希望数据库脱机以进行文件还原,请在开始还原序列之前执行下列 ALTER DATABASE 语句以使数据库脱机:ALTER DATABASE database_name SET OFFLINE。

从文件备份还原损坏的文件

  1. 在还原一个或多个损坏的文件前,请尝试创建 结尾日志备份

    如果该日志已损坏,则不能创建结尾日志备份,您必须还原整个数据库。

    有关如何备份事务日志的信息,请参阅事务日志备份 (SQL Server)

    重要

    对于脱机文件还原,在文件还原之前必须始终先进行一次结尾日志备份。 对于联机文件还原,在文件还原之后必须始终先进行一次日志备份。 此日志备份对于将文件恢复到与数据库的其余部分一致的状态至关重要。

  2. 从每个损坏的文件的最新文件备份还原相应文件。

  3. 针对每个还原的文件,还原最近的差异文件备份(如果有)。

  4. 按顺序还原事务日志备份,从覆盖最早还原文件的备份开始,到在步骤 1 中创建的结尾日志备份结束。

    必须还原在文件备份后创建的事务日志备份才能使数据库处于一致状态。 事务日志备份可以快速前滚,因为仅应用了对还原文件所做的更改。 与还原整个数据库相比,更好的方式是还原单个文件,因为并不会复制并随后前滚未损坏的文件。 但是,仍需要读取整个日志备份链。

  5. 恢复数据库。

注意

文件备份可用于将数据库还原到早期时间点。 必须还原一组完整的文件备份,然后依次将事务日志备份还原到目标点(目标点是结束最近还原的文件备份后的时间点),才能执行此操作。 有关时点恢复的详细信息,请参阅将 SQL Server 数据库还原到某个时间点(完整恢复模式)

脱机文件还原的 Transact-SQL 还原顺序(完整恢复模式)

文件还原方案由复制、前滚和恢复相应数据的单一还原顺序组成。

本节说明用于文件还原序列的基本 RESTORE 选项。 将省略与此目的不相关的语法和详细信息。

以下示例说明了如何使用 WITH NORECOVERY 脱机还原两个辅助文件 AB。 随后,对两个日志备份应用 NORECOVERY,然后是结尾日志备份(用 WITH RECOVERY 还原)。

注意

下面的示例还原序列通过使文件脱机开始,然后创建结尾日志备份,

--Take the file offline.  
ALTER DATABASE database_name MODIFY FILE SET OFFLINE;  
-- Back up the currently active transaction log.  
BACKUP LOG database_name  
   TO <tail_log_backup>  
   WITH NORECOVERY;  
GO   
-- Restore the files.  
RESTORE DATABASE database_name FILE=name   
   FROM <file_backup_of_file_A>   
   WITH NORECOVERY;  
RESTORE DATABASE database_name FILE=<name> ......  
   FROM <file_backup_of_file_B>   
   WITH NORECOVERY;  
-- Restore the log backups.  
RESTORE LOG database_name FROM <log_backup>   
   WITH NORECOVERY;  
RESTORE LOG database_name FROM <log_backup>   
   WITH NORECOVERY;  
RESTORE LOG database_name FROM <tail_log_backup>   
   WITH RECOVERY;  

示例

相关任务

还原文件和文件组

另请参阅

备份和还原:互操作性和共存 (SQL Server)
差异备份 (SQL Server)
完整文件备份 (SQL Server)
Backup Overview (SQL Server)
还原和恢复概述 (SQL Server)
RESTORE (Transact-SQL)
完整数据库还原(简单恢复模式)
段落还原 (SQL Server)