应用事务日志备份 (SQL Server)
适用范围:SQL Server
本主题只与完整恢复模式或大容量日志恢复模式相关。
本主题介绍在还原 SQL Server 数据库过程中应用事务日志备份。
还原事务日志备份的要求
若要应用事务日志备份,必须满足下列要求:
为还原顺序准备足够的日志备份: 您必须备份足够的日志记录才能完成还原顺序。 必要的日志备份(需要时包含 结尾日志备份 )必须在还原顺序开始之前可用。
正确的还原顺序: 必须先还原紧位于前面的完整数据库备份或差异数据库备份。 然后,在完整数据库备份或差异数据库备份后创建的所有事务日志必须按时间顺序还原。 如果此事务日志链中的事务日志备份丢失或损坏,则您只能还原丢失的事务日志之前的事务日志。
数据库尚未恢复: 直到应用完最后一个的事务日志之后,才能恢复数据库。 如果要在还原其中一个中间事务日志备份之后恢复数据库,则在日志链结束之前,除非从完整数据库备份开始重新启动整个还原顺序,否则,将无法还原该点之前的数据库。
提示
最佳方法是还原所有日志备份 (
RESTORE LOG *database_name* WITH NORECOVERY
)。 还原上一次日志备份后,用单独的操作恢复数据库 (RESTORE DATABASE *database_name* WITH RECOVERY
)。
恢复和事务日志
完成还原操作并恢复数据库后,将执行恢复过程,以确保数据库的完整性。 有关恢复过程的详细信息,请参阅还原和恢复概述 (SQL Server)。
恢复过程完成后,数据库将进入联机状态,不能再将其他事务日志备份应用到数据库。 例如,一系列事务日志备份包含一个运行时间长的事务。 该事务的起点记录在第一个事务日志备份中,终点记录在第二个事务日志备份中。 第一个事务日志备份中没有任何关于提交或回滚操作的记录。 如果在应用第一个事务日志备份后运行恢复操作,则运行时间长的事务被视为未完成,并且将回滚事务的第一个事务日志备份中记录的数据修改。 SQL Server 不允许在此时点后应用第二个事务日志备份。
注意
某些情况下可以在日志还原期间显式添加文件。
使用日志备份来还原到故障点
假设有下列事件顺序。
时间 | 事件 |
---|---|
上午 8:00 | 备份数据库以创建完整数据库备份。 |
中午 | 备份事务日志。 |
下午 4:00 | 备份事务日志。 |
下午 6:00 | 备份数据库以创建完整数据库备份。 |
晚上 8:00 | 备份事务日志。 |
晚上 9:45 | 出现故障。 |
有关此示例备份顺序的说明,请参阅事务日志备份 (SQL Server)。
要将数据库还原到晚上 9:45 的状态(故障时点),可以使用以下任一备选过程:
备选过程 1:使用最新的完整数据库备份还原数据库
失败时创建当前活动事务日志的结尾日志备份。
请勿还原上午 8:00 的完整数据库备份。 相反,还原最近的下午 6:00 的完整数据库备份,然后应用晚上 8:00 的日志备份和结尾日志备份。
备选过程 2:使用较早的完整数据库备份还原数据库
如果因某个问题而无法使用下午 6:00 的完整数据库备份,则此备选过程很有用。 此过程比从下午 6:00 的完整数据库备份还原所需的时间更长。
失败时创建当前活动事务日志的结尾日志备份。
还原上午 8:00 的完整数据库备份,然后按顺序还原所有四个事务日志备份。 所有完成的事务都将前滚到晚上 9:45。
此备选过程指出了冗余安全性,该安全性通过维护一系列完整数据库备份中的事务日志链备份来获得。
某些情况下,您还可以使用事务日志将数据库还原到特定的时间点。 有关详细信息,请参阅将 SQL Server 数据库还原到某个时间点(完整恢复模式)。
相关任务
应用事务日志备份
还原到恢复点
SqlRestore (SMO)
使用 WITH NORECOVERY 在还原备份后恢复数据库