错误:SQL数据库还原失败,因为数据库正在使用中

当你使用T-SQL或SSMS来恢复SQL数据库时,有时会出现“无法获得独占访问,因为数据库正在使用中”的错误,并且有问题的数据库后面会出现一个“正在恢复... ”的标记,这会阻止您对其进行任何正常操作。

恢复正在使用的失败数据库

是什么原因导致SQL数据库卡在恢复中问题?可能是另一个用户正在使用数据库,或者数据库文件在重建过程中被同步。无论如何,我在这里列出了几种行之有效的方法,您可以一一尝试以修复SQL数据库还原失败,因为数据库正在使用问题:

“🔹注意”:在尝试这些方法之前,请先检查是否有您在完成查询任务后忘记关闭的SQLQuery窗口。如果有,关闭它,sql server数据库恢复问题就可以直接解决了。

方式 1. 关闭与目标数据库的现有连接

如果您更喜欢使用 SSMS GUI,请尝试在“还原数据库”窗口中再勾选一个选项以关闭与目标数据库的所有现有连接。

1. 与正常操作类似,启动 SSMS 并连接到您的实例,然后右键单击要还原的数据库并选择“任务”>“还原”>“数据库”

2. 在弹出窗口中,选择“设备”并指定要从中恢复的 bak 文件。

3. 切换到“选项选项”卡,然后勾选“关闭与目标数据库的现有连接”选项。然后单击“确定”执行恢复。数据库正在使用错误不会再弹出。

关闭现有连接

方式二、将SQL Server切换到单用户模式

由于数据库被其他用户使用可能会导致SQL Server恢复失败,所以可以将SQL Server切换到单用户模式,然后再设置为多用户模式。这也将关闭所有活动连接。

启动 SSMS 并连接到实例,然后您可以使用以下命令创建“新查询:”

USE master;
GO
ALTER DATABASE databasename
SET SINGLE_USER
WITH ROLLBACK IMMEDIATE;
ALTER DATABASE databasename
SET MULTI_USER;
GO

切换到单人模式

方式 3. 恢复SQL Server数据库

还有另一个简单的技巧可以修复正在使用的 SQL数据库恢复失败的数据库,即使用 RECOVERY 恢复有问题的数据库。

单击“新建查询”并在窗口中输入此命令:

RESTORE DATABASE 数据库名称 WITH RECOVERY

当您断开实例并重新连接时,您会发现数据库后面的“正在恢复”标记已被删除。

使用 recovery 恢复数据库

方式 4. 将默认数据库改回 master

SQL Server 数据库恢复问题有时是由于您使用目标数据库作为其默认数据库登录,这将始终保持连接会话活动。要修复它,您需要将默认数据库更改回“master”。

1. 在 SSMS 中连接到您的实例,导航到对象资源管理器中的“安全”>“登录并找到您的登录用户”。

2. 右击选择“属性”。在弹出的登录属性窗口中,您会在底部找到“默认数据库”。展开其下拉菜单并选择master

3. 点击确定“确认”。然后您可以再次尝试恢复目标数据库。

方式五、彻底重启SQL Server服务

这更像是最后的手段。如果其他方法都失败了,那么你可以尝试彻底重启SQL服务。

1. 按Win + R并在文本框中输入“services.msc”。单击“确定”运行它。

2、找到对应实例的SQL服务,如SQL Server(MSSQLSERVER)。

3. 右键单击​​该服务将其“停止”,然后再次“启动”它。

重启sqlserver服务

方式6.使用安全替代方案顺利恢复SQL数据库

数据库正在使用错误在SQL Server恢复中并不少见。就我而言,在使用T-SQL命令恢复多个数据库时经常出现,而且每次都一个一个修复,真的很麻烦。因此,您可以考虑使用更简单的替代方法来管理 SQL数据库备份和顺利恢复。在这里我想用傲梅企业备份网络版举个例子。

其SQL Server备份功能支持SQL 2005-2019,让您可以一次选择多个数据库进行备份或恢复。作为集中式管理解决方案,它不仅适用于您自己的 PC,还适用于局域网内的所有计算机。这样你也可以备份 SQL数据库并恢复到另一台服务器.

凭借其简洁的界面,任何操作都可以通过几个简单的步骤完成。不仅是SQL Server,它还支持 Windows 中的其他数据类型,例如“文件、分区、磁盘和操作系统”

创建SQL Server数据库备份任务:

1.正确安装软件和客户端包,获得对您要管理的计算机的控制权。

请求控制

然后你可以去"任务"选项卡,选择"新任务"并选择"SQL Server备份"

sql服务器备份

2、在步骤1中点击“+添加计算机”,检测到带有SQL数据库的客户端计算机,选择需要备份的客户端。

添加电脑

3. 在第2步中点击“+添加”检测所选计算机上的所有实例,并根据需要选择数据库。

选择数据库

4、在步骤3中,点击“添加存储”,添加一个share或者NAS设备作为存储端。然后“开始备份”

“设置:”您可以在此处启用电子邮件通知。
“计划:”创建计划以运行备份一次/每天/每周/每月。“高级”选项卡中还包含完整备份和差异备份选项。

选择目标路径

从备份中恢复SQL Server数据库:

1.创建的备份任务将显示在“任务选项”卡中。您可以单击其右上角的“高级”以从备份中“还原”。

恢复sql服务器

2. 选择要从中还原的计算机及其数据库。如果您已经多次备份它们(完整或差异),您还可以在右上角选择要恢复的特定备份。

选择计算机和数据库

3. 您可以将这些数据库恢复到原始位置或新位置。使用第二个选项,您可以直接将数据库还原到另一个 SQL Server。然后,单击“开始还原”以执行它。

“覆盖现有数据库”:勾选此选项后,备份的数据库将覆盖同名的现有数据库。否则,在恢复过程中将跳过具有相同名称的数据库。

恢复到原始或新位置

结论

SQL Server 还原失败,因为数据库正在使用中?这里有几种解决方案可能对您有用,但它们不能防止类似问题再次发生。为了节省您宝贵的时间和精力,您可以试用傲梅企业备份网络版,它可以直观地完成数据库的备份和恢复操作。

作为一个全面的备份解决方案,它不仅适用于SQL Server数据库,还适用于文件、分区、操作系统和磁盘等计算机数据。有了它,你甚至可以执行集中系统备份适用于 LAN 内的所有计算机。