可以分离数据库的数据和事务日志文件,然后将其重新附加到相同或另一个 SQL Server 实例。 如果要将数据库更改为同一计算机上的不同SQL Server实例或移动数据库,则分离和附加数据库非常有用。
SQL Server磁盘存储格式在 64 位和 32 位环境中相同。 因此,可以将 32 位环境中的数据库附加到 64 位环境中,反之亦然。 从运行在某个环境中的服务器实例上分离的数据库可以附加到运行在另一个环境中的服务器实例。
安全性
文件访问权限可在很多数据库操作过程中设置,其中包括分离或附加数据库。
重要
建议您不要附加或还原来自未知或不可信源的数据库。 此类数据库可能包含恶意代码,这些代码可能会执行非预期的 Transact-SQL 代码,或者通过修改架构或物理数据库结构导致错误。 使用来自未知源或不可信源的数据库前,请在非生产服务器上针对数据库运行 DBCC CHECKDB ,然后检查数据库中的代码,例如存储过程或其他用户定义代码。
分离数据库
分离数据库会将数据库从 SQL Server 实例中删除,但使数据库在其数据文件和事务日志文件中保持不变。 然后,可以使用这些文件将数据库附加到SQL Server的任何实例,包括从中分离数据库的服务器。
如果存在下列任何情况,则不能分离数据库:
已复制并发布数据库。 如果进行复制,则数据库必须是未发布的。 必须通过运行 sp_replicationdboption禁用发布后,才能分离数据库。
注意
如果无法使用 sp_replicationdboption,可以通过运行 sp_removedbreplication删除复制。
数据库中存在数据库快照。
必须首先删除所有数据库快照,然后才能分离数据库。 有关详细信息,请参阅 删除数据库快照 (Transact-SQL) 。
注意
不能分离或附加数据库快照。
该数据库正在某个数据库镜像会话中进行镜像。
除非终止该会话,否则无法分离该数据库。 有关详细信息,请参阅删除数据库镜像 (SQL Server)。
数据库处于可疑状态。 无法分离可疑数据库;必须将数据库设为紧急模式,才能对其进行分离。 有关如何将数据库置于紧急模式的详细信息,请参阅 ALTER DATABASE (Transact-SQL) 。
数据库为系统数据库。
备份、还原及分离
分离只读数据库将会丢失有关差异备份的差异基准的信息。 有关详细信息,请参阅差异备份 (SQL Server)。
响应分离错误
分离数据库时生成的错误会阻止完全关闭数据库和重新生成事务日志。 收到错误消息后,请执行下列更正操作:
重新附加与数据库关联的所有文件,而不仅仅是主文件。
解决导致生成错误消息的问题。
再次分离数据库。
附加数据库
可以附加复制或分离SQL Server数据库。 附加 SQL Server 2014 服务器实例时,目录文件会从以前的位置附加到其他数据库文件,与 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) 。
附加时,数据库会启动。 通常,附加数据库时会将数据库重置为它分离或复制时的状态。 但是,附加和分离操作都会禁用数据库的跨数据库所有权链接。 有关如何启用链接的详细信息,请参阅 cross db ownership chaining 服务器配置选项。 此外,附加数据库时,TRUSTWORTHY 均设置为 OFF。 有关如何将 TRUSTWORTHY 设置为 ON 的信息,请参阅 ALTER DATABASE (Transact-SQL) 。
备份、还原及附加
与任何完全或部分脱机的数据库一样,不能附加正在还原文件的数据库。 如果停止了还原顺序,则可以附加数据库。 然后,可以重新启动还原顺序。
将数据库附加到其他服务器实例
重要
无法在早期版本的 SQL Server 中附加由较新版本的 SQL Server 创建的数据库。
将数据库附加到其他服务器实例时,为了给用户和应用程序提供一致的体验,您最好在其他服务器实例上为数据库重新创建部分或全部元数据(例如登录名和作业)。 有关详细信息,请参阅当数据库在其他服务器实例上可用时管理元数据 (SQL Server)。
Related Tasks
分离数据库
附加数据库
使用分离和附加操作升级数据库
使用分离和附加操作移动数据库
删除数据库快照