分离数据库和附加数据库

可以分离数据库的数据和事务日志文件,然后将它们重新附加到同一或其他 SQL Server 实例。如果要将数据库更改到同一计算机的不同 SQL Server 实例或要移动数据库,分离和附加数据库会很有用。

注意注意

在 64 位和 32 位环境中,SQL Server 磁盘存储格式均相同。因此,可以将 32 位环境中的数据库附加到 64 位环境中,反之亦然。从运行在某个环境中的服务器实例上分离的数据库可以附加到运行在另一个环境中的服务器实例。

有关分离或附加数据库时设置的文件权限的信息,请参阅保护数据和日志文件的安全

安全性

文件访问权限可在很多数据库操作过程中设置,其中包括分离或附加数据库。有关分离或附加数据库时设置的文件权限的信息,请参阅保护数据和日志文件的安全

安全说明安全说明

建议您不要从未知或不可信源附加或还原数据库。此类数据库可能包含恶意代码,这些代码可能会执行非预期的 Transact-SQL 代码,或者通过修改架构或物理数据库结构导致错误。使用来自未知源或不可信源的数据库前,请在非生产服务器上针对数据库运行 DBCC CHECKDB,然后检查数据库中的代码,例如存储过程或其他用户定义代码。

分离数据库

分离数据库是指将数据库从 SQL Server 实例中删除,但使数据库在其数据文件和事务日志文件中保持不变。之后,就可以使用这些文件将数据库附加到任何 SQL Server 实例,包括分离该数据库的服务器。

如果存在下列任何情况,则不能分离数据库:

  • 已复制并发布数据库。如果进行复制,则数据库必须是未发布的。必须通过运行 sp_replicationdboption 禁用发布后,才能分离数据库。

    注意注意

    如果无法使用 sp_replicationdboption,可以通过运行 sp_removedbreplication 删除复制。

  • 数据库中存在数据库快照。

    必须首先删除所有数据库快照,然后才能分离数据库。有关详细信息,请参阅如何删除数据库快照 (Transact-SQL)

    注意注意

    不能分离或附加数据库快照。

  • 该数据库正在某个数据库镜像会话中进行镜像。

    除非终止该会话,否则无法分离该数据库。有关详细信息,请参阅删除数据库镜像

  • 数据库处于可疑状态。在 SQL Server 2005 和更高版本中,无法分离可疑数据库;必须将数据库设为紧急模式,才能对其进行分离。有关如何将数据库置入紧急模式的详细信息,请参阅 ALTER DATABASE (Transact-SQL)

  • 该数据库是系统数据库。

分离数据库

备份、还原及分离

分离只读数据库将会丢失有关差异备份的差异基准的信息。有关详细信息,请参阅备份只读数据库

响应分离错误

分离数据库时生成的错误会阻止完全关闭数据库和重新生成事务日志。收到错误消息后,请执行下列更正操作:

  1. 重新附加与数据库关联的所有文件,而不仅仅是主文件。

  2. 解决导致生成错误消息的问题。

  3. 再次分离数据库。

附加数据库

您可以附加复制的或分离的 SQL Server 数据库。当将包含全文目录文件的 SQL Server 2005 数据库附加到 SQL Server 2008 服务器实例上时,会将目录文件从其以前的位置与其他数据库文件一起附加,这与在 SQL Server 2005 中的情况相同。有关详细信息,请参阅全文搜索升级

附加数据库时,所有数据文件(MDF 文件和 NDF 文件)都必须可用。如果任何数据文件的路径不同于首次创建数据库或上次附加数据库时的路径,则必须指定文件的当前路径。

注意注意

如果附加的主数据文件是只读的,则数据库引擎假定数据库也是只读的。

当加密的数据库首次附加到 SQL Server 实例时,数据库所有者必须通过执行下面的语句打开数据库的主密钥:OPEN MASTER KEY DECRYPTION BY PASSWORD = 'password'。建议您通过执行下面的语句对主密钥启用自动解密:ALTER MASTER KEY ADD ENCRYPTION BY SERVICE MASTER KEY。有关详细信息,请参阅 CREATE MASTER KEY (Transact-SQL)ALTER MASTER KEY (Transact-SQL)

附加日志文件的要求在某些方面取决于数据库是读写的还是只读的,如下所示:

  • 对于读写数据库,通常可以附加新位置中的日志文件。不过,在某些情况下,重新附加数据库需要使用其现有的日志文件。因此,请务必保留所有分离的日志文件,直到在不需要这些日志文件的情况下成功附加了数据库。

    如果读写数据库具有单个日志文件,并且您没有为该日志文件指定新位置,附加操作将在旧位置中查找该文件。如果找到了旧日志文件,则无论数据库上次是否完全关闭,都将使用该文件。但是,如果未找到旧文件日志,数据库上次是完全关闭且现在没有活动日志链,则附加操作将尝试为数据库创建新的日志文件。有关详细信息,请参阅事务日志逻辑体系结构事务日志物理体系结构

  • 如果附加的主数据文件是只读的,则数据库引擎假定数据库也是只读的。对于只读数据库,日志文件在数据库主文件中指定的位置上必须可用。因为 SQL Server 无法更新主文件中存储的日志位置,所以无法生成新的日志文件。

附加数据库时更改元数据

分离再重新附加只读数据库后,会丢失有关当前差异基准的备份信息。“差异基准”是数据库或其文件或文件组子集中所有数据的最新完整备份。如果没有基准备份信息,master 数据库会变得与只读数据库不同步,这样之后进行的差异备份可能会产生意外结果。因此,如果对只读数据库使用差异备份,在重新附加数据库后,应通过进行完整备份来建立新的差异基准。有关详细信息,请参阅差异备份的基准

附加时,数据库会启动。通常,附加数据库时会将数据库重置为它分离或复制时的状态。但是,在 SQL Server 2005 和更高版本中,附加和分离操作都会禁用数据库的跨数据库所有权链接。有关如何启用链接的信息,请参阅 cross db ownership chaining 选项。此外,附加数据库时,TRUSTWORTHY 均设置为 OFF。有关如何将 TRUSTWORTHY 设置为 ON 的信息,请参阅 ALTER DATABASE (Transact-SQL)

备份、还原及附加

与任何完全或部分脱机的数据库一样,不能附加正在还原文件的数据库。如果停止了还原顺序,则可以附加数据库。然后,可以重新启动还原顺序。

将数据库附加到其他服务器实例

将数据库附加到其他服务器实例时,为了给用户和应用程序提供一致的体验,您最好在其他服务器实例上为数据库重新创建部分或全部元数据(例如登录名和作业)。有关详细信息,请参阅当数据库在其他服务器实例上可用时管理元数据

注意注意

无法在早期版本的 SQL Server 中附加由较新版本的 SQL Server 创建的数据库。

附加数据库

从 SQL Server 的早期版本升级数据库

在 SQL Server 2008 中,可以使用分离和附加操作将用户数据库从 SQL Server 2000 或 SQL Server 2005 升级。但是,存在下列限制:

  • 不能附加使用 SQL Server 2000 或 SQL Server 2005 创建的 mastermodelmsdb 数据库的副本。

  • 附加复制的而不是分离的复制数据库时:

    • 如果将该数据库附加到同一服务器实例的升级版本中,必须在附加操作完成后执行 sp_vupgrade_replication 来升级复制数据库。有关详细信息,请参阅 sp_vupgrade_replication (Transact-SQL)

    • 如果您将数据库附加到不同的服务器实例,而不考虑版本,则必须执行 sp_removedbreplication 才能在附加操作完成后删除复制。有关详细信息,请参阅 sp_removedbreplication (Transact-SQL)

使用分离和附加操作升级数据库

移动数据库或数据库文件

重要说明重要提示

建议您使用 ALTER DATABASE 计划重定位过程(而不使用分离和附加操作)移动数据库。有关详细信息,请参阅移动数据库文件

通常,您可以使用分离和附加操作移动数据库。典型方案包括将数据库移动到下列位置之一:

  • 相同计算机上的不同物理磁盘。例如,当包含数据文件的磁盘空间不足,并且您希望展开现有文件(而不是通过在不同磁盘上添加新文件来展开数据库)。

  • 其他计算机;不必重新创建数据库和还原数据库备份。

使用分离和附加操作移动数据库分为以下阶段:

  1. 分离数据库。

  2. 将数据库文件移到其他服务器或磁盘上。

  3. 通过指定移动文件的新位置附加数据库。

使用分离和附加操作移动数据库