AIOps 一场颠覆传统运维的盛筵
865
2022-10-08
MSSQL日常运维之在完整恢复模式下将数据库还原到故障点 (Transact-SQL)
MSSQL日常运维之在完整恢复模式下将数据库还原到故障点 (Transact-SQL)
本文说明如何还原到故障点。本主题仅与那些使用完整或大容量日志恢复模式的数据库相关。还原到故障点通过运行以下基本 BACKUP 语句来备份日志尾部:
BACKUP LOG
通过运行以下基本 RESTORE DATABASE 语句来还原完整数据库备份:
RESTORE DATABASE
或者,通过运行以下基本 RESTORE DATABASE 语句来还原差异数据库备份:
RESTORE DATABASE
通过在 RESTORE LOG 语句中指定 WITH NORECOVERY 以应用每个事务日志(包括步骤 1 中创建的结尾日志备份):
RESTORE LOG
通过运行以下 RESTORE DATABASE 语句来恢复数据库:
RESTORE DATABASE
示例必须先完成下列准备工作,才能运行此示例:AdventureWorks2012 数据库的默认恢复模式是简单恢复模式。由于该恢复模式不支持还原到故障点,因此请将 AdventureWorks2012 设置为使用完整恢复模式,方法是运行以下 ALTER DATABASE 语句:
USE master; GOALTER DATABASE AdventureWorks2012 SET RECOVERY FULL;
通过使用以下 BACKUP 语句,创建数据库的完整数据库备份:
BACKUP DATABASE AdventureWorks2012 TO DISK = 'C:\AdventureWorks2012_Data.bck';
创建例程日志备份:
BACKUP LOG AdventureWorks2012 TO DISK = 'C:\AdventureWorks2012_Log.bck';
以下示例在创建 AdventureWorks2012 数据库的结尾日志备份后,将还原先前创建的备份。(此步骤假设可以访问日志磁盘。)首先,该示例将创建捕获活动日志的数据库结尾日志备份,并使数据库处于还原状态。然后,该示例将还原数据库备份,应用先前创建的例程日志备份,并应用结尾日志备份。最后,该示例将在单独的步骤中恢复数据库。
/* Example of restoring a to the point of failure */-- Step 1: Create a tail-log backup by using WITH NORECOVERY. BACKUP LOG AdventureWorks2012 TO DISK = 'C:\AdventureWorks2012_Log.bck'WITH NORECOVERY; GO -- Step 2: Restore the full database backup. RESTORE DATABASE AdventureWorks2012 FROM DISK = 'C:\AdventureWorks2012_Data.bck'WITH NORECOVERY; GO -- Step 3: Restore the first transaction log backup. RESTORE LOG AdventureWorks2012 FROM DISK = 'C:\AdventureWorks2012_Log.bck'WITH NORECOVERY; GO -- Step 4: Restore the tail-log backup. RESTORE LOG AdventureWorks2012 FROM DISK = 'C:\AdventureWorks2012_Log.bck'WITH NORECOVERY; GO -- Step 5: Recover the database. RESTORE DATABASE AdventureWorks2012 WITH RECOVERY; GO
发表评论
暂时没有评论,来抢沙发吧~