RESTORE 语句 (Transact-SQL)

还原使用 BACKUP 命令所做的 SQL 数据库备份。

选择一个产品

在下面的行中,选择你感兴趣的产品名称,系统将只显示该产品的信息。

有关语法约定的详细信息,请参阅 Transact-SQL 语法约定

* SQL Server *  

 

SQL Server

通过此命令,您可以执行下列还原方案:

  • 基于完整数据库备份还原整个数据库(完整还原)。
  • 还原数据库的一部分(部分还原)。
  • 将特定文件或文件组还原到数据库(文件还原)。
  • 将特定页面还原到数据库(页面还原)。
  • 将事务日志还原到数据库(事务日志还原)。
  • 将数据库恢复到数据库快照捕获的时间点。

其他资源

语法

--To Restore an Entire Database from a Full database backup (a Complete Restore):
RESTORE DATABASE { database_name | @database_name_var }
 [ FROM <backup_device> [ ,...n ] ]
 [ WITH
   {
    [ RECOVERY | NORECOVERY | STANDBY =
        {standby_file_name | @standby_file_name_var }
       ]
   | ,  <general_WITH_options> [ ,...n ]
   | , <replication_WITH_option>
   | , <change_data_capture_WITH_option>
   | , <FILESTREAM_WITH_option>
   | , <service_broker_WITH options>
   | , <point_in_time_WITH_options-RESTORE_DATABASE>
   } [ ,...n ]
 ]
[;]

--To perform the first step of the initial restore sequence of a piecemeal restore:
RESTORE DATABASE { database_name | @database_name_var }
   <files_or_filegroups> [ ,...n ]
 [ FROM <backup_device> [ ,...n ] ]
   WITH
      PARTIAL, NORECOVERY
      [  , <general_WITH_options> [ ,...n ]
       | , <point_in_time_WITH_options-RESTORE_DATABASE>
      ] [ ,...n ]
[;]

--To Restore Specific Files or Filegroups:
RESTORE DATABASE { database_name | @database_name_var }
   <file_or_filegroup> [ ,...n ]
 [ FROM <backup_device> [ ,...n ] ]
   WITH
   {
      [ RECOVERY | NORECOVERY ]
      [ , <general_WITH_options> [ ,...n ] ]
   } [ ,...n ]
[;]

--To Restore Specific Pages:
RESTORE DATABASE { database_name | @database_name_var }
   PAGE = 'file:page [ ,...n ]'
 [ , <file_or_filegroups> ] [ ,...n ]
 [ FROM <backup_device> [ ,...n ] ]
   WITH
       NORECOVERY
      [ , <general_WITH_options> [ ,...n ] ]
[;]

--To Restore a Transaction Log:
RESTORE LOG { database_name | @database_name_var }
 [ <file_or_filegroup_or_pages> [ ,...n ] ]
 [ FROM <backup_device> [ ,...n ] ]
 [ WITH
   {
     [ RECOVERY | NORECOVERY | STANDBY =
        {standby_file_name | @standby_file_name_var }
       ]
    | , <general_WITH_options> [ ,...n ]
    | , <replication_WITH_option>
    | , <point_in_time_WITH_options-RESTORE_LOG>
   } [ ,...n ]
 ]
[;]

--To Revert a Database to a Database Snapshot:
RESTORE DATABASE { database_name | @database_name_var }
FROM DATABASE_SNAPSHOT = database_snapshot_name

<backup_device>::=
{
   { logical_backup_device_name |
      @logical_backup_device_name_var }
 | { DISK
     | TAPE
     | URL
   } = { 'physical_backup_device_name' |
      @physical_backup_device_name_var }
}

<files_or_filegroups>::=
{
   FILE = { logical_file_name_in_backup | @logical_file_name_in_backup_var }
 | FILEGROUP = { logical_filegroup_name | @logical_filegroup_name_var }
 | READ_WRITE_FILEGROUPS
}

<general_WITH_options> [ ,...n ]::=
--Restore Operation Options
   MOVE 'logical_file_name_in_backup' TO 'operating_system_file_name'
          [ ,...n ]
 | REPLACE
 | RESTART
 | RESTRICTED_USER | CREDENTIAL

--Backup Set Options
 | FILE = { backup_set_file_number | @backup_set_file_number }
 | PASSWORD = { password | @password_variable }
 | [ METADATA_ONLY | SNAPSHOT ] [ DBNAME = { database_name | @database_name_variable } ]

--Media Set Options
 | MEDIANAME = { media_name | @media_name_variable }
 | MEDIAPASSWORD = { mediapassword | @mediapassword_variable }
 | BLOCKSIZE = { blocksize | @blocksize_variable }

--Data Transfer Options
 | BUFFERCOUNT = { buffercount | @buffercount_variable }
 | MAXTRANSFERSIZE = { maxtransfersize | @maxtransfersize_variable }

--Error Management Options
 | { CHECKSUM | NO_CHECKSUM }
 | { STOP_ON_ERROR | CONTINUE_AFTER_ERROR }

--Monitoring Options
 | STATS [ = percentage ]

--Tape Options.
 | { REWIND | NOREWIND }
 | { UNLOAD | NOUNLOAD }

<replication_WITH_option>::=
 | KEEP_REPLICATION

<change_data_capture_WITH_option>::=
 | KEEP_CDC

<FILESTREAM_WITH_option>::=
 | FILESTREAM ( DIRECTORY_NAME = directory_name )

<service_broker_WITH_options>::=
 | ENABLE_BROKER
 | ERROR_BROKER_CONVERSATIONS
 | NEW_BROKER

<point_in_time_WITH_options-RESTORE_DATABASE>::=
 | {
   STOPAT = { 'datetime'| @datetime_var }
 | STOPATMARK = 'lsn:lsn_number'
                 [ AFTER 'datetime']
 | STOPBEFOREMARK = 'lsn:lsn_number'
                 [ AFTER 'datetime']
   }

<point_in_time_WITH_options-RESTORE_LOG>::=
 | {
   STOPAT = { 'datetime'| @datetime_var }
 | STOPATMARK = { 'mark_name' | 'lsn:lsn_number' }
                 [ AFTER 'datetime']
 | STOPBEFOREMARK = { 'mark_name' | 'lsn:lsn_number' }
                 [ AFTER 'datetime']
   }

参数

有关参数的说明,请参阅 RESTORE 参数

关于还原方案

SQL Server 支持各种还原方案:

在支持联机还原的情况下,如果数据库为联机状态,则文件还原和页面还原将自动为联机还原,同时在段落还原的初始阶段之后,辅助文件组也变为联机还原。

注意

联机还原可能会涉及延迟的事务

有关详细信息,请参阅联机还原

有关 RESTORE 选项的其他注意事项

废止的 RESTORE 关键字

SQL Server 2008 (10.0.x) 中已停止使用以下关键字:

停止使用的关键字 替换为… 替换关键字的示例
LOAD RESTORE RESTORE DATABASE
TRANSACTION LOG RESTORE LOG
DBO_ONLY RESTRICTED_USER RESTORE DATABASE ... WITH RESTRICTED_USER

RESTORE LOG

RESTORE LOG 可以包括一个文件列表,从而允许在前滚过程中创建文件。 这可用于下列情况:将文件添加到数据库时,日志备份包含了已写入的日志记录。

注意

对于使用完全恢复模式或大容量日志恢复模式的数据库,在大多数情况下,您必须在还原数据库前备份日志的结尾。 还原数据库而不首先备份日志的末尾将导致错误,除非 RESTORE DATABASE 语句包含 WITH REPLACE 或 WITH STOPAT 子句,此子句必须指定数据备份的结束时间或在数据备份结束之后发生的事务。 有关结尾日志备份的详细信息,请参阅结尾日志备份

RECOVERY 和 NORECOVERY 的比较

回滚由 RESTORE 语句通过 [ RECOVERY | NORECOVERY ] 选项控制:

  • NORECOVERY 指定不发生回滚。 从而使前滚按顺序在下一条语句中继续进行。

    在这种情况下,还原顺序可还原其他备份,并执行前滚。

  • RECOVERY(默认值)表示,应在完成当前备份前滚之后执行回滚。 无法还原其他备份。 还原所有必需的备份后,请选择此选项。

    恢复数据库要求要还原的整个数据集(“前滚集”)必须与数据库一致。 如果前滚集尚未前滚到与数据库保持一致的地步,并且指定了 RECOVERY,数据库引擎将发出错误。 有关恢复过程的详细信息,请参阅还原和恢复概述 (SQL Server)

兼容性支持

SQL Server 无法还原使用 SQL Server 早期版本创建的 mastermodelmsdb 备份。

注意

无法将 SQL Server 备份还原到比创建该备份的版本还早的版本。

SQL Server 的每个版本使用的默认路径与早期版本不同。 因此,若要还原在早期版本备份的默认位置创建的数据库,必须使用 MOVE 选项。 有关新的默认路径的信息,请参阅 SQL Server 的默认实例和命名实例的文件位置

在你将早期版本数据库还原到 SQL Server 后,将自动升级该数据库。 通常,该数据库将立即可用。 但是,如果 SQL Server 2005 (9.x) 数据库具有全文检索,升级过程将导入、重置或重新生成它们,具体取决于 upgrade_option 服务器属性的设置。 如果将升级选项设置为“导入”(upgrade_option = 2) 或“重新生成”(upgrade_option = 0),在升级过程中将无法使用全文检索。 导入可能需要数小时,而重新生成所需的时间最多时可能十倍于此,具体取决于要编制索引的数据量。 另请注意,如果将升级选项设置为“导入”,并且全文目录不可用,则会重新生成关联的全文索引。 若要更改 upgrade_option 服务器属性的设置,请使用 sp_fulltext_service

当数据库第一次附加或还原到新的 SQL Server实例时,数据库主密钥(由服务主密钥加密)的副本尚未存储在服务器中。 必须使用 OPEN MASTER KEY 语句解密数据库主密钥 (DMK)。 一旦 DMK 解密后,通过使用 ALTER MASTER KEY REGENERATE 语句向服务器提供 DMK(使用服务主密钥 (SMK) 加密)的副本,即可拥有将来启用自动解密的选项。 当数据库已从较早版本升级后,应重新生成 DMK 以使用更新的 AES 算法。 有关重新生成 DMK 的详细信息,请参阅 ALTER MASTER KEY。 重新生成 DMK 密钥以升级到 AES 所需的时间取决于 DMK 保护的对象数。 重新生成 DMK 密钥以升级到 AES 只在必需时执行一次,不影响将来作为密钥循环策略的一部分而重新生成的过程。

备注

在脱机还原过程中,如果指定的数据库正在使用,则在短暂延迟之后,RESTORE 将强制用户离线。 对于非主文件组的联机还原,除非要还原的文件组为脱机状态,否则数据库可以保持使用状态。 指定数据库中的所有数据都将由还原的数据替换。

只要操作系统支持数据库排序规则,就可以跨平台执行还原操作,即使这些平台使用不同的处理器类型也不例外。

RESTORE 在出现错误之后可以重新启动。 此外,你可以指示 RESTORE 继续进行而不必考虑错误,此命令可还原尽可能多的数据(请参阅 CONTINUE_AFTER_ERROR 选项)。

不允许在显式或隐式事务中使用 RESTORE。

还原已损坏的 master 数据库需要使用特殊的过程。 有关详细信息,请参阅备份和还原系统数据库

还原数据库会清除要还原的数据库的计划缓存。 清除计划缓存将导致对所有后续执行计划进行重新编译,并可能导致查询性能暂时性地突然降低。

要还原可用性数据库,首先需要将数据库还原成 SQL Server 的实例,然后再将数据库添加到可用性组。

用于备份压缩和解压缩的集成加速和卸载

SQL Server 2022 (16.x) 引入了 ALGORITHM,用于标识操作的压缩算法。 有关详细信息,请参阅备份压缩

有关详细信息,请参阅还原操作

从 URL 还原

URL 是用于为 Microsoft Azure Blob 存储或 S3 兼容对象存储指定位置和文件名的格式。 虽然 Azure Blob 存储是一种服务,不过实现与磁盘和磁带类似,从而可为所有设备提供一致且无缝的还原体验。

互操作性

数据库设置和还原

在还原过程中,可使用 ALTER DATABASE 设置的大多数数据库选项将强制重置为备份结束时的值。

但是,使用 WITH RESTRICTED_USER 选项将覆盖用户访问选项设置的此行为。 此设置总是通过在 RESTORE 语句后加上 WITH RESTRICTED_USER 选项来设置。

还原加密数据库

若要还原已加密的数据库,您必须有权访问用于对数据库进行加密的证书或非对称密钥。 如果没有证书或非对称密钥,数据库将无法还原。 因此,只要需要该备份,就必须保留用于对数据库加密密钥进行加密的证书。 有关详细信息,请参阅 SQL Server Certificates and Asymmetric Keys

还原为 vardecimal 存储启用的数据库

使用 vardecimal 存储格式时,备份和还原可正常进行。 有关 vardecimal 存储格式的详细信息,请参阅 sp_db_vardecimal_storage_format

还原全文数据

全文数据与其他数据库数据一同在完全还原过程中还原。 使用常规 RESTORE DATABASE database_name FROM backup_device 语法,将全文文件作为数据库文件还原的一部分进行还原。

RESTORE 语句也可用于对全文数据执行替代位置还原、差异还原、文件和文件组还原,以及差异文件和文件组还原。 此外,RESTORE 可以仅还原全文文件,也可以同时还原数据库数据。

注意

从 SQL Server 2005 (9.x) 导入的全文目录仍然被视为数据库文件。 对于这些目录,用于备份全文目录的 SQL Server 2005 (9.x) 过程仍然适用,只是在备份操作期间不再需要暂停和恢复。 有关详细信息,请参阅备份和还原全文目录

还原到 SQL Server 2022 和自动删除功能

将数据库从以前的版本还原到 SQL Server 2022 (16.x) 时,建议对数据库执行 sp_updatestats,并为统计信息自动删除功能设置适当的元数据。 有关详细信息,请参阅统计信息自动删除选项

SQL Server 大数据群集

某些操作(包括配置服务器(实例级)设置或手动将数据库添加到可用性组)需要连接到 SQL Server 实例。 某些操作(例如 sp_configureRESTORE DATABASE 或属于可用性组的数据库中的任何 DDL 命令)需要连接到 SQL Server 实例。 默认情况下,大数据群集不包含用于连接到实例的终结点。 必须手动公开此终结点。

有关说明,请参阅连接到主副本上的数据库

元数据

SQL Server 包含备份和还原历史记录表,这些表可以跟踪每个服务器实例的备份和还原活动。 执行还原时,还将修改备份历史记录表。 有关这些表的信息,请参阅备份历史记录和标头信息

REPLACE 选项的影响

应尽可能避免使用 REPLACE,而且在使用该选项之前必须仔细考虑。 还原一般会防止意外使用一个数据库覆盖另一个数据库。 如果 RESTORE 语句中指定的数据库已存在于当前服务器上,并且指定的数据库系列 GUID 与备份集中记录的数据库系列 GUID 不同,则不还原该数据库。 这是一项重要的安全保护措施。

使用 REPLACE 选项后,就会忽略还原时通常执行的几项重要安全检查。 忽略的检查如下:

  • 还原时使用其他数据库的备份覆盖现有数据库。

    使用 REPLACE 选项后,即使指定的数据库名称与备份集中记录的数据库名称不同,还原也允许您使用备份集中任何一个数据库覆盖现有数据库。 这会导致一个数据库意外覆盖另一个数据库。

  • 在没有获取结尾日志备份并也没有使用 STOPAT 选项的情况下,使用完整恢复模式或大容量日志恢复模式对数据库进行还原。

    使用 REPLACE 选项后,由于没有备份最近写入的日志,您会丢失提交的作业。

  • 覆盖现有文件。

    例如,可能会错误地覆盖错误类型的文件,如 .xls 文件或非联机状态的其他数据库正在使用的文件等。 如果覆盖现有文件,则即使所还原的数据库是完整的,也有可能丢失某些数据。

恢复还原

还原结果是无法撤消的,但可以文件为基础重新开始操作而使数据复制和前滚的结果无效。 若要重新开始,请再次还原所需的文件并执行前滚。 例如,如果您不慎还原了过多的日志备份并超过了预期停止点,则必须重新启动该顺序。

通过还原受影响文件的全部内容,可以中止并重新启动还原顺序。

将数据库还原到数据库快照

“恢复数据库操作”(使用 DATABASE_SNAPSHOT 选项指定)用于及时执行完整的源数据库恢复,该过程将使源数据库恢复到数据库快照时的状态,就是说,用在指定的数据库快照中维护的时间点数据覆盖源数据库。 当前只能存在可以恢复到的快照。 然后,恢复操作重新生成日志(因此,以后无法将已恢复的数据库前滚到用户错误点)。

丢失的数据仅限于创建快照后数据库更新的数据。 已恢复的数据库的元数据与创建快照时的元数据相同。 但是,恢复到快照将删除所有全文目录。

从数据库快照恢复不适用于介质恢复。 与定期备份集不同,数据库快照并非数据库文件的完整副本。 如果数据库或数据库快照已损坏,则可能无法从快照恢复。 即便可以恢复,但是如果损坏的话,恢复可能也无法更正该问题。

对还原的限制

下列情况不支持恢复:

  • 源数据库包含任何只读或压缩的文件组。
  • 某些在创建快照时处于在线状态的文件已离线。
  • 当前存在多个数据库快照。

有关详细信息,请参阅将数据库恢复到数据库快照

安全性

在备份时,可以根据需要为介质集、备份集或这两者指定密码。 如果已经在介质集或备份集上定义了密码,则必须在 RESTORE 语句中指定正确的密码。 这些密码可防止未经授权而使用 SQL Server 工具执行还原操作以及向介质追加备份集。 但是,可以通过 BACKUP 语句的 FORMAT 选项覆盖受密码保护的介质。

重要

此密码提供的安全性较低。 它旨在防止经过授权的用户或未经授权的用户使用 SQL Server 工具执行不正确的还原操作。 但是不能防止通过其他方式或通过替换密码来读取备份数据。 在 SQL Server的未来版本中将删除此功能。 请避免在新的开发工作中使用该功能,并着手修改当前还在使用该功能的应用程序。 保护备份的最佳做法是将备份磁带存储在安全的位置,或者备份到由适当的访问控制列表 (ACL) 保护的磁盘文件。 ACL 应设置在创建备份的根目录下。

权限

如果不存在要还原的数据库,则用户必须有 CREATE DATABASE 权限才能执行 RESTORE。 如果数据库存在,则 RESTORE 权限默认授予 sysadmindbcreator 固定服务器角色成员以及数据库的所有者 (dbo)(对于 FROM DATABASE_SNAPSHOT 选项,数据库始终存在)。

RESTORE 权限被授予那些成员身份信息始终可由服务器使用的角色。 因为只有在固定数据库可以访问且没有损坏时(在执行 RESTORE 时并不会总是这样)才能检查固定数据库角色成员身份,所以 db_owner 固定数据库角色成员没有 RESTORE 权限。

示例

所有的示例均假定已执行了完整数据库备份。

RESTORE 示例包括:

注意

有关其他示例,请参阅还原和恢复概述中列出的还原操作指南主题。

A. 还原完整的数据库

下面的示例从 AdventureWorksBackups 逻辑备份设备还原完整数据库备份。 有关创建此设备的示例,请参阅备份设备

RESTORE DATABASE AdventureWorks2022
  FROM AdventureWorks2022Backups;

注意

对于使用完全恢复模式或大容量日志恢复模式的数据库,在大多数情况下,SQL Server 都要求您在还原数据库前备份日志尾部。 有关详细信息,请参阅结尾日志备份

[返回示例顶部]

B. 还原完整数据库备份和差异数据库备份

下面的示例还原完整数据库备份后,从同时还包含差异数据库备份的 Z:\SQLServerBackups\AdventureWorks2022.bak 备份设备还原差异备份。 要还原的完整数据库备份是设备上的第六个备份集 (FILE = 6),差异数据库备份是设备上的第九个备份集 (FILE = 9)。 在恢复了差异备份之后,便恢复了数据库。

RESTORE DATABASE AdventureWorks2022
    FROM DISK = 'Z:\SQLServerBackups\AdventureWorks2022.bak'
    WITH FILE = 6,
      NORECOVERY;
RESTORE DATABASE AdventureWorks2022
    FROM DISK = 'Z:\SQLServerBackups\AdventureWorks2022.bak'
    WITH FILE = 9,
      RECOVERY;

[返回示例顶部]

C. 使用 RESTART 语法还原数据库

下面的示例使用 RESTART 选项重新启动因服务器电源故障而中断的 RESTORE 操作。

-- This database RESTORE halted prematurely due to power failure.
RESTORE DATABASE AdventureWorks2022
    FROM AdventureWorksBackups;
-- Here is the RESTORE RESTART operation.
RESTORE DATABASE AdventureWorks2022
    FROM AdventureWorksBackups WITH RESTART;

[返回示例顶部]

D. 还原数据库并移动文件

下面的示例还原完整数据库和事务日志,并将还原后的数据库移动到 C:\Program Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER\MSSQL\Data 目录中。

RESTORE DATABASE AdventureWorks2022
    FROM AdventureWorksBackups
    WITH NORECOVERY,
      MOVE 'AdventureWorks2022_Data' TO
'C:\Program Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER\MSSQL\Data\NewAdvWorks.mdf',
      MOVE 'AdventureWorks2022_Log'
TO 'C:\Program Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER\MSSQL\Data\NewAdvWorks.ldf';
RESTORE LOG AdventureWorks2022
    FROM AdventureWorksBackups
    WITH RECOVERY;

[返回示例顶部]

E. 使用 BACKUP 和 RESTORE 复制数据库

下面的示例使用 BACKUPRESTORE 语句创建 AdventureWorks2022 数据库的副本。 MOVE 语句使数据和日志文件还原到指定的位置。 RESTORE FILELISTONLY 语句用于确定待还原数据库内的文件数及名称。 该数据库的新副本称为 TestDB。 有关详细信息,请参阅 RESTORE FILELISTONLY

BACKUP DATABASE AdventureWorks2022
    TO AdventureWorksBackups ;

RESTORE FILELISTONLY
    FROM AdventureWorksBackups ;

RESTORE DATABASE TestDB
    FROM AdventureWorksBackups
    WITH MOVE 'AdventureWorks2022_Data' TO 'C:\MySQLServer\testdb.mdf',
    MOVE 'AdventureWorks2022_Log' TO 'C:\MySQLServer\testdb.ldf';
GO

[返回示例顶部]

F. 使用 STOPAT 还原到时间点

下面的示例将数据库还原到它在 12:00 AMApril 15, 2020 的状态,并显示涉及多个日志备份的还原操作。 在备份设备上,要还原的完整数据库备份 AdventureWorksBackups是设备上的第三个备份集 (FILE = 3),第一个日志备份是第四个备份集 (FILE = 4),第二个日志备份是第五个备份集 (FILE = 5)。

RESTORE DATABASE AdventureWorks2022
    FROM AdventureWorksBackups
    WITH FILE = 3, NORECOVERY;

RESTORE LOG AdventureWorks2022
    FROM AdventureWorksBackups
    WITH FILE = 4, NORECOVERY, STOPAT = 'Apr 15, 2020 12:00 AM';

RESTORE LOG AdventureWorks2022
    FROM AdventureWorksBackups
    WITH FILE = 5, NORECOVERY, STOPAT = 'Apr 15, 2020 12:00 AM';
RESTORE DATABASE AdventureWorks2022 WITH RECOVERY;

[返回示例顶部]

G. 将事务日志还原到标记

下面的示例将事务日志还原到名为 ListPriceUpdate的标记事务中的标记处。

USE AdventureWorks2022;
GO
BEGIN TRANSACTION ListPriceUpdate
    WITH MARK 'UPDATE Product list prices';
GO

UPDATE Production.Product
    SET ListPrice = ListPrice * 1.10
    WHERE ProductNumber LIKE 'BK-%';
GO

COMMIT TRANSACTION ListPriceUpdate;
GO

-- Time passes. Regular database
-- and log backups are taken.
-- An error occurs in the database.
USE master;
GO

RESTORE DATABASE AdventureWorks2022
FROM AdventureWorksBackups
WITH FILE = 3, NORECOVERY;
GO

RESTORE LOG AdventureWorks2022
  FROM AdventureWorksBackups
    WITH FILE = 4,
    RECOVERY,
    STOPATMARK = 'UPDATE Product list prices';

[返回示例顶部]

H. 使用 TAPE 语法还原

下面的示例从 TAPE 备份设备还原完整数据库备份。

RESTORE DATABASE AdventureWorks2022
    FROM TAPE = '\\.\tape0';

[返回示例顶部]

I. 使用 FILE 和 FILEGROUP 语法还原

下面的示例还原名为 MyDatabase 的数据库,该数据库有两个文件、一个辅助文件组和一个事务日志。 数据库使用完整恢复模式。

该数据库备份是名为 MyDatabaseBackups 的逻辑备份设备上的介质集中的第九个备份集。 接下来,通过使用 10 来还原在 11 设备上的后续三个备份集(12MyDatabaseBackupsWITH NORECOVERY)中的三个日志备份。 使用 NORECOVERY 还原最后一个日志备份之后,应当恢复数据库。

注意

恢复应当作为单独的步骤执行,以减少在还原所有日志备份之前太早进行恢复的可能性。 有关恢复过程的详细信息,请参阅还原和恢复概述 (SQL Server)

RESTORE DATABASE 中,请注意有两种 FILE 选项类型。 在备份设备名称前面的 FILE 选项用于指定要从备份集还原的数据库文件的逻辑文件名;例如,FILE = 'MyDatabase_data_1'。 此备份集不是介质集中的第一个数据库备份;因此,应当通过在 FILE 子句中使用 WITH 选项(即 FILE = 9)来指示它在介质集中的位置。

RESTORE DATABASE MyDatabase
    FILE = 'MyDatabase_data_1',
    FILE = 'MyDatabase_data_2',
    FILEGROUP = 'new_customers'
    FROM MyDatabaseBackups
    WITH
      FILE = 9,
      NORECOVERY;
GO
-- Restore the log backups
RESTORE LOG MyDatabase
    FROM MyDatabaseBackups
    WITH FILE = 10,
      NORECOVERY;
GO
RESTORE LOG MyDatabase
    FROM MyDatabaseBackups
    WITH FILE = 11,
      NORECOVERY;
GO
RESTORE LOG MyDatabase
    FROM MyDatabaseBackups
    WITH FILE = 12,
      NORECOVERY;
GO
--Recover the database
RESTORE DATABASE MyDatabase WITH RECOVERY;
GO

[返回示例顶部]

J. 从数据库快照还原

下面的示例将数据库恢复到数据库快照。 该示例假定该数据库当前仅存在一个快照。 有关如何创建此数据库快照的示例,请参阅创建数据库快照

注意

恢复到快照将删除所有全文目录。

USE master;
RESTORE DATABASE AdventureWorks2022 FROM DATABASE_SNAPSHOT = 'AdventureWorks_dbss1800';
GO

有关详细信息,请参阅将数据库恢复到数据库快照

[返回示例顶部]

K. 从 Microsoft Azure Blob 存储还原

以下三个示例都涉及 Microsoft Azure 存储服务的使用。 存储帐户名称为 mystorageaccount。 数据文件的容器称为 myfirstcontainer。 备份文件的容器称为 mysecondcontainer。 已为每个容器创建具有读取、写入、删除和列表权限的存储访问策略。 已使用与存储访问策略相关联的共享访问签名创建 SQL Server 凭据。 针对使用 Microsoft Azure Blob 存储进行 SQL Server 备份和还原的信息,请参阅使用 Microsoft Azure Blob 存储进行 SQL Server 备份和还原

K1. 从 Microsoft Azure 存储服务还原完整数据库备份
位于 mysecondcontainerSales 的完整数据库备份将还原到 myfirstcontainerSales 当前不在服务器上。

RESTORE DATABASE Sales
  FROM URL = 'https://mystorageaccount.blob.core.windows.net/mysecondcontainer/Sales.bak'
  WITH MOVE 'Sales_Data1' to 'https://mystorageaccount.blob.core.windows.net/myfirstcontainer/Sales_Data1.mdf',
  MOVE 'Sales_log' to 'https://mystorageaccount.blob.core.windows.net/myfirstcontainer/Sales_log.ldf',
  STATS = 10;

K2. 将完整数据库备份从 Microsoft Azure 存储服务还原到本地存储 位于 mysecondcontainerSales 的完整数据库备份将还原到本地存储。 Sales 当前不在服务器上。

RESTORE DATABASE Sales
  FROM URL = 'https://mystorageaccount.blob.core.windows.net/mysecondcontainer/Sales.bak'
  WITH MOVE 'Sales_Data1' to 'H:\DATA\Sales_Data1.mdf',
  MOVE 'Sales_log' to 'O:\LOG\Sales_log.ldf',
  STATS = 10;

K3. 将完整数据库备份从本地存储还原到 Microsoft Azure 存储服务

RESTORE DATABASE Sales
  FROM DISK = 'E:\BAK\Sales.bak'
  WITH MOVE 'Sales_Data1' to 'https://mystorageaccount.blob.core.windows.net/myfirstcontainer/Sales_Data1.mdf',
  MOVE 'Sales_log' to 'https://mystorageaccount.blob.core.windows.net/myfirstcontainer/Sales_log.ldf',
  STATS = 10;

L. 从快照备份还原

在 SQL Server 2022 (16.x) 中引入。 有关详细信息,请参阅创建 Transact-SQL 快照备份

L1. 还原完整备份

RESTORE DATABASE Sales
  FROM DISK = 'D:\MSSQL\Backup\SalesSnapshotFull.bkm'
  WITH METADATA_ONLY;

L2. 还原备份并应用事务日志

RESTORE DATABASE Sales
  FROM DISK = 'D:\MSSQL\Backup\SalesSnapshotFull.bkm'
  WITH METADATA_ONLY,
  NORECOVERY;

RESTORE LOG Sales
  FROM DISK = 'D:\MSSQL\Backup\SalesLog.trn'
  WITH RECOVERY;

L3. 从快照备份还原并将数据库和日志文件放置在新位置

RESTORE DATABASE Sales
FROM DISK = 'D:\MSSQL\Backup\SalesSnapshotFull.bkm'
WITH METADATA_ONLY,
    MOVE Sales_Data TO 'D:\MSSQL\Sales.mdf',
    MOVE Sales_Log TO 'D:\MSSQL\Sales_log.ldf';

[返回示例顶部]

后续步骤

* SQL 托管实例 *

 

Azure SQL 托管实例

运行此命令,可通过 Azure Blob 存储帐户从完整数据库备份(完整还原)还原整个数据库。

有关其他受支持的 RESTORE 命令,请参阅:

重要

若要从 SQL 托管实例自动备份还原,请参阅 SQL 数据库还原

语法

--To Restore an Entire Database from a Full database backup (a Complete Restore):
RESTORE DATABASE { database_name | @database_name_var }
 FROM URL = { 'physical_device_name' | @physical_device_name_var } [ ,...n ]
[;]

参数

DATABASE

指定目标数据库。

FROM URL

指定放置在将用于还原操作的 URL 上的一个或多个备份设备。 URL 格式用于从 Microsoft Azure 存储服务还原备份。

重要

从 URL 还原时,若要从多个设备进行还原,必须使用共享访问签名 (SAS) 令牌。 有关创建共享访问签名的示例,请参阅 SQL Server 备份到 URL使用 Powershell 简化在 Azure 存储空间中使用共享访问签名 (SAS) 令牌创建 SQL 凭据的过程

n 一个占位符,表示最多可以在逗号分隔的列表中指定 64 个备份设备。

注解

前提条件是,必须通过将共享访问签名设为机密,创建名称与 blob 存储帐户 URL 一致的凭据。 RESTORE 命令将使用 blob 存储 URL 查找凭据,以找到读取备份设备所需的信息。

RESTORE 操作是异步的,即使客户端连接中断,还原也会继续运行。 如果连接断开,可检查 sys.dm_operation_status 视图,查看还原操作的状态(以及查看 CREATE 和 DROP 数据库)。

已设置/覆盖以下数据库选项,这些选项稍后无法进行更改:

  • NEW_BROKER(如果 .bak 文件中未启用中转站)
  • ENABLE_BROKER(如果 .bak 文件中未启用中转站)
  • AUTO_CLOSE=OFF(如果 .bak 文件中的数据库具有 AUTO_CLOSE=ON)
  • RECOVERY FULL(如果 .bak 文件中的数据库具有 SIMPLE 或 BULK_LOGGED 恢复模式)
  • 如果源 .bak 文件中不存在内存优化文件组,则会添加一个,并将其命名为 XTP。 任何现有内存优化文件组都会重命名为 XTP
  • SINGLE_USER 和 RESTRICTED_USER 选项会转换为 MULTI_USER

限制 - SQL 托管实例

这些限制包括:

  • 无法还原包含多个备份集的 .BAK 文件。
  • 无法还原包含多个日志文件的 .BAK 文件。
  • 如果 .bak 中包含 FILESTREAM 数据,则还原将失败。
  • 如果备份中包含的数据库具有活动的内存中对象,则该备份无法还原到常规用途性能层。
  • 如果备份包含处于只读模式的数据库,则该备份当前无法还原。

有关详细信息,请参阅 Azure SQL 托管实例

还原加密数据库

若要还原已加密的数据库,您必须有权访问用于对数据库进行加密的证书或非对称密钥。 如果没有证书或非对称密钥,数据库将无法还原。 因此,只要需要该备份,就必须保留用于对数据库加密密钥进行加密的证书。 有关详细信息,请参阅 SQL Server Certificates and Asymmetric Keys

权限

用户必须拥有 CREATE DATABASE 权限,才能运行 RESTORE。

CREATE LOGIN mylogin WITH PASSWORD = 'Very Strong Pwd123!';
GRANT CREATE ANY DATABASE TO [mylogin];

RESTORE 权限被授予那些成员身份信息始终可由服务器使用的角色。 因为只有在固定数据库可以访问且没有损坏时(在执行 RESTORE 时并不会总是这样)才能检查固定数据库角色成员身份,所以 db_owner 固定数据库角色成员没有 RESTORE 权限。

示例

以下示例从 URL 还原仅复制的数据库备份,包括创建凭据。

A. 从四个备份设备还原数据库

-- Create credential
CREATE CREDENTIAL [https://mybackups.blob.core.windows.net/wide-world-importers]
WITH IDENTITY = 'SHARED ACCESS SIGNATURE',
      SECRET = 'sv=2017-11-09&ss=bq&srt=sco&sp=rl&se=2022-06-19T22:41:07Z&st=2018-06-01T14:41:07Z&spr=https&sig=s7wddcf0w%3D';
GO
-- Restore database
RESTORE DATABASE WideWorldImportersStandard
FROM URL = N'https://mybackups.blob.core.windows.net/wide-world-importers/00-WideWorldImporters-Standard.bak',
URL = N'https://mybackups.blob.core.windows.net/wide-world-importers/01-WideWorldImporters-Standard.bak',
URL = N'https://mybackups.blob.core.windows.net/wide-world-importers/02-WideWorldImporters-Standard.bak',
URL = N'https://mybackups.blob.core.windows.net/wide-world-importers/03-WideWorldImporters-Standard.bak'

如果数据库已存在,则显示以下错误:Msg 1801, Level 16, State 1, Line 9 Database 'WideWorldImportersStandard' already exists. Choose a different database name.

B. 通过变量还原指定数据库

DECLARE @db_name sysname = 'WideWorldImportersStandard';
DECLARE @url nvarchar(400) = N'https://mybackups.blob.core.windows.net/wide-world-importers/WideWorldImporters-Standard.bak';

RESTORE DATABASE @db_name
FROM URL = @url

C. 跟踪还原语句的执行进度

SELECT query = a.text, start_time, percent_complete,
    eta = dateadd(second,estimated_completion_time/1000, getdate())
FROM sys.dm_exec_requests r
    CROSS APPLY sys.dm_exec_sql_text(r.sql_handle) a
WHERE r.command = 'RESTORE DATABASE'

注意

此视图可能会显示两个还原请求。 一个是客户端发送的原始 RESTORE 语句,另一个是在客户端连接失败时仍执行的后台 RESTORE 语句。

* Analytics
Platform System (PDW) *

 

分析平台系统

将 Analytics Platform System (PDW) 用户数据库从数据库备份还原到 Analytics Platform System (PDW) 设备。 数据库会从以前通过 Analytics Platform System (PDW) BACKUP DATABASE - Analytics Platform System 命令创建的备份进行还原。 使用备份和还原操作生成灾难恢复计划,或将数据库从一个设备移动到另一个。

注意

还原 master 系统数据库包括还原设备登录信息。 若要还原 master 数据库,请使用 Configuration Manager 工具中的还原 master 数据库页面。 有权访问控制节点的管理员可以执行此操作。 有关 Analytics Platform System (PDW) 数据库备份的详细信息,请参阅 Analytics Platform System (PDW) 产品文档中的“备份和还原”。

语法

-- Restore the master database
-- Use the Configuration Manager tool.

Restore a full user database backup.
RESTORE DATABASE database_name
    FROM DISK = '\\UNC_path\full_backup_directory'
[;]

--Restore a full user database backup and then a differential backup.
RESTORE DATABASE database_name
    FROM DISK = '\\UNC_path\differential_backup_directory'
    WITH [ ( ] BASE = '\\UNC_path\full_backup_directory' [ ) ]
[;]

--Restore header information for a full or differential user database backup.
RESTORE HEADERONLY
    FROM DISK = '\\UNC_path\backup_directory'
[;]

参数

RESTORE DATABASE database_name

指定要将用户数据库还原到名为 database_name 的数据库。 还原的数据库可以具有与备份的源数据库不同的名称。database_name 不能作为数据库已存在于目标设备上。 有关允许的数据库名称的详细信息,请参阅 Analytics Platform System (PDW) 产品文档中的“对象命名规则”。

还原用户数据库会还原完整数据库备份,然后可以选择将差异备份还原到设备。 用户数据库的还原包括还原数据库用户和数据库角色。

FROM DISK = '\\UNC_path\backup_directory'

Analytics Platform System (PDW) 将从中还原备份文件的网络路径和目录。 例如,FROM DISK = '\\xxx.xxx.xxx.xxx\backups\2012\Monthly\08.2012.Mybackup'。

backup_directory 指定包含完整或差异备份的目录的名称。 例如,可以对完整或差异备份执行 RESTORE HEADERONLY 操作。

full_backup_directory 指定包含完整备份的目录的名称。

differential_backup_directory 指定包含差异备份的目录的名称。

  • 路径和备份目录必须已存在,并且必须指定为完全限定的通用命名约定 (UNC) 路径。
  • 备份目录的路径不能是本地路径,并且不能是任何Analytics Platform System (PDW)设备节点上的位置。
  • UNC 路径和备份目录名称的最大长度为 200 个字符。
  • 必须以 IP 地址的形式指定服务器或主机。

RESTORE HEADERONLY

指定仅返回一个用户数据库备份的标头信息。 在其他字段中,标头包括备份的文本说明和备份名称。 备份名称无需与用于存储备份文的目录的名称相同。

RESTORE HEADERONLY 结果会在 SQL Server RESTORE HEADERONLY 结果之后模式化。 结果具有 50 多列,Analytics Platform System (PDW) 并不使用所有这些列。 有关 SQL Server RESTORE HEADERONLY 结果中的列的说明,请参阅 RESTORE HEADERONLY

权限

需要 CREATE ANY DATABASE 权限。

需要有权访问和读取备份目录的 Windows 帐户。 还必须将 Windows 帐户名称和密码存储在Analytics Platform System (PDW)中。

错误处理

RESTORE DATABASE 命令会在以下情况下导致错误:

  • 要还原的数据库的名称已在目标设备上存在。 若要避免此问题,请选择唯一的数据库名称,或在运行还原之前删除现有数据库。
  • 备份目录中存在一组无效的备份文件。
  • 登录权限不足以还原数据库。
  • Analytics Platform System (PDW) 对备份文件所处的网络位置不拥有正确权限。
  • 备份目录的网络位置不存在或不可用。
  • 计算节点或控制节点上的磁盘空间不足。 Analytics Platform System (PDW) 不会在启动还原之前确认设备上是否存在足够磁盘空间。 因此,运行 RESTORE DATABASE 语句时可能会生成磁盘空间不足错误。 磁盘空间不足时,Analytics Platform System (PDW) 会回滚还原。
  • 数据库还原到的目标设备的计算节点比从中备份数据库的源设备更少。
  • 从事务中尝试进行数据库还原。

备注

Analytics Platform System (PDW) 会跟踪数据库还原是否成功。 还原差异数据库备份之前,Analytics Platform System (PDW) 会验证完整数据库还原是否已成功完成。

还原之后,用户数据库会具有数据库兼容级别 120。 这适用于所有数据库(与其原始兼容级别无关)。

还原到计算节点数更大的设备

在将数据库从较小设备还原到较大设备之后运行 DBCC SHRINKLOG (Azure Synapse Analytics),因为重新分发会增加事务日志。

将备份还原到计算节点数更大的设备会与计算节点数成比例地增加分配的数据库大小。

例如,将 60 GB 数据库从 2 节点设备(每个节点 30 GB)还原到 6 节点设备时,Analytics Platform System (PDW) 会在 6 节点设备上创建 180 GB 数据库(6 个节点,每个节点 30 GB)。 Analytics Platform System (PDW) 最初将数据库还原到 2 个节点以匹配源配置,然后将数据重新分发到所有 6 个节点。

重新分发之后,与较小源设备上的每个计算节点相比,每个计算节点都会包含较少的实际数据和较多的可用空间。 使用附加空间可将更多数据添加到数据库。 如果还原的数据库大小大于所需大小,则可以使用 ALTER DATABASE - PDW 收缩数据库文件大小。

限制和局限

对于这些限制和局限,源设备是从中创建数据库备份的设备,而目标设备是将数据库还原到的设备。

  • 还原数据库不会自动重新生成统计信息。
  • 在任何给定时间,只有一个 RESTORE DATABASE 或 BACKUP DATABASE 语句可以在设备上运行。 如果同时提交多个备份和还原语句,则设备会将它们放入队列中,一次处理一个。
  • 只能将数据库备份还原到计算节点数等于或多于源设备的 Analytics Platform System (PDW) 目标设备。 目标设备的计算节点数不能少于源设备。
  • 无法将在具有 SQL Server 2012 PDW 硬件的设备上创建的备份还原到具有 SQL Server 2008 R2 硬件的设备。 即使设备在最初购买时具有 SQL Server 2008 R2 PDW 硬件,而现在正在运行 SQL Server 2012 PDW 软件,情况也是如此。

锁定

在 DATABASE 对象上采用排他锁。

示例

A. 简单 RESTORE 示例

下面的示例将完整备份还原到 SalesInvoices2013 数据库。 备份文件存储在 \\\xxx.xxx.xxx.xxx\backups\yearly\Invoices2013Full 目录中。 SalesInvoices2013 数据库不能已在目标设备上存在,否则此命令会失败并出错。

RESTORE DATABASE SalesInvoices2013
FROM DISK = '\\xxx.xxx.xxx.xxx\backups\yearly\Invoices2013Full';

B. 还原完整和差异备份

下面的示例依次将完整备份和差异备份还原到 SalesInvoices2013 数据库

数据库的完整备份从存储在 \\\xxx.xxx.xxx.xxx\backups\yearly\Invoices2013Full 目录中的完整备份还原。 如果还原成功完成,则差异备份会还原到 SalesInvoices2013 数据库。 差异备份存储在 \\\xxx.xxx.xxx.xxx\backups\yearly\Invoices2013Diff 目录中。

RESTORE DATABASE SalesInvoices2013
    FROM DISK = '\\xxx.xxx.xxx.xxx\backups\yearly\Invoices2013Diff'
    WITH BASE = '\\xxx.xxx.xxx.xxx\backups\yearly\Invoices2013Full'
[;]

C. 还原备份标头

此示例将还原数据库备份 \\\xxx.xxx.xxx.xxx\backups\yearly\Invoices2013Full 的标头信息。 该命令会为 Invoices2013Full 备份生成一行信息。

RESTORE HEADERONLY
    FROM DISK = '\\xxx.xxx.xxx.xxx\backups\yearly\Invoices2013Full'
[;]

可以使用标头信息检查备份的内容,或者在尝试还原备份之前确保目标还原设备与源备份设备兼容。

后续步骤