我需要帮助设置在SINGLE_USER模式恢复到MULTI_USER的数据库。每次我奔跑

ALTER DATABASE BARDABARD
SET MULTI_USER;
GO

我得到这个错误:

目前不能更改数据库'BARDABARD'的状态或选项。 数据库处于单用户模式,当前有用户连接到数据库。

它需要在非SINGLE_USER模式下将其设置为另一种模式,但当它是SINGLE_USER模式时,我不能将数据库设置为任何其他模式。


当前回答

进入单用户模式后,客户端只能与SQL Server建立一个连接,记住“对象资源管理器”占用一个(单独的)连接,所以如果你试图在查询窗口中运行多用户语句,你会得到在单用户模式下无法建立另一个连接的错误。

但对我来说,这不是问题,在我的情况下,很少有自动进程持续地(每隔几秒钟)建立连接,所以一旦我将DB设置为单用户模式并断开连接,其中一个进程就建立/占用了连接(在我可以开始恢复操作之前)。一旦我杀死这些连接,它们就会重新连接,当我运行恢复命令时,我会得到连接已经被占用的错误。

为了解决这个问题,我不得不在一个查询窗口中编写kill语句,更改User-Mode语句和Restore操作,当我一次性运行它们时,瞧!!它工作。

希望这能帮助到其他人。

其他回答

进入单用户模式后,客户端只能与SQL Server建立一个连接,记住“对象资源管理器”占用一个(单独的)连接,所以如果你试图在查询窗口中运行多用户语句,你会得到在单用户模式下无法建立另一个连接的错误。

但对我来说,这不是问题,在我的情况下,很少有自动进程持续地(每隔几秒钟)建立连接,所以一旦我将DB设置为单用户模式并断开连接,其中一个进程就建立/占用了连接(在我可以开始恢复操作之前)。一旦我杀死这些连接,它们就会重新连接,当我运行恢复命令时,我会得到连接已经被占用的错误。

为了解决这个问题,我不得不在一个查询窗口中编写kill语句,更改User-Mode语句和Restore操作,当我一次性运行它们时,瞧!!它工作。

希望这能帮助到其他人。

在超过3次使用SQL Server 2014的情况下,我有一个数据库转换为单用户模式,而我没有做任何改变。它一定是在数据库创建过程中以某种方式发生的。上面所有的方法从来没有工作过,因为我总是收到一个错误,数据库处于单用户模式,无法连接到。

我唯一要做的就是重新启动SQL Server Windows服务。这允许我连接到数据库并进行必要的更改,或者删除数据库并重新开始。

我和当地的数据库出了点问题。

我能够通过停止SQL server来解决这个问题,然后启动SQL server,然后使用SSMS UI将DB属性更改为Multi_User。

当我试图恢复备份时,数据库进入“单用户”模式。在尝试恢复之前,我没有创建目标数据库的备份(SQL 2017)。这样你每次都能成功。

停止SQL Server,启动SQL Server,然后运行上述脚本或使用用户界面。

我轻而易举地解决了这个问题

右键单击数据库名称,重命名它 更改后,右键单击数据库名称—>属性—>选项—>滚动限制性访问底部(SINGLE_USER到MULTI_USER) 现在,您可以再次将数据库重命名为您的旧名称。

“用户当前连接到它”可能是SQL Server Management Studio窗口本身。尝试选择主数据库并再次运行ALTER查询。