目前,我的数据库处于单用户模式。当我试图扩展我的数据库,我得到一个错误:
数据库my_db不可访问。
此外,当我试图删除数据库时,我得到错误:
无法更改数据库'my_db'的状态或选项 这一次。数据库为单用户模式,用户为 当前连接到它。
如何退出单用户模式?我没有任何用户使用这个数据库。
当我尝试用IIS浏览我的网站时,我得到的错误是:
类的执行期间生成了未处理的异常 当前的web请求。关于起源和位置的信息 可以使用下面的异常堆栈跟踪来识别异常。
我觉得这是单用户模式造成的。
目前,我的数据库处于单用户模式。当我试图扩展我的数据库,我得到一个错误:
数据库my_db不可访问。
此外,当我试图删除数据库时,我得到错误:
无法更改数据库'my_db'的状态或选项 这一次。数据库为单用户模式,用户为 当前连接到它。
如何退出单用户模式?我没有任何用户使用这个数据库。
当我尝试用IIS浏览我的网站时,我得到的错误是:
类的执行期间生成了未处理的异常 当前的web请求。关于起源和位置的信息 可以使用下面的异常堆栈跟踪来识别异常。
我觉得这是单用户模式造成的。
当前回答
不确定这是否对任何人都有帮助,但我也有同样的问题,找不到阻碍我的过程。我关闭了SSMS并停止了所有访问本地实例的服务。然后,当我返回并运行exec sp_who2时,它显示了罪魁祸首。我杀死了进程,并能够让Multi_User工作,然后重新启动服务。我们让IIS每隔几分钟/秒就会搜索特定的包。
其他回答
在Jespers的回答中,为了更有效地补充:
SET DEADLOCK_PRIORITY 10;-- Be the top dog.
SET DEADLOCK_PRIORITY HIGH使用DEADLOCK_PRIORITY为5。
发生的事情是,其他进程在数据库中受到了破坏,如果您的进程具有较低的DEADLOCK_PRIORITY,那么它就会输掉这场比赛。
这避免了寻找和杀死另一只蜘蛛(这可能需要做几次)。
您可能需要运行ALTER DATABASE不止一次(但Jesper会这样做)。修改代码:
USE [master]
SET DEADLOCK_PRIORITY HIGH
exec sp_dboption '[StuckDB]', 'single user', 'FALSE';
ALTER DATABASE [StuckDB] SET MULTI_USER WITH NO_WAIT
ALTER DATABASE [StuckDB] SET MULTI_USER WITH ROLLBACK IMMEDIATE
右键单击数据库部分中的数据库 选择“属性” 选择“选项”页 向下滚动“其他选项”并更改“限制访问”字段
我试过了,有效果
ALTER DATABASE dbName SET MULTI_USER WITH ROLLBACK IMMEDIATE
不确定这是否对任何人都有帮助,但我也有同样的问题,找不到阻碍我的过程。我关闭了SSMS并停止了所有访问本地实例的服务。然后,当我返回并运行exec sp_who2时,它显示了罪魁祸首。我杀死了进程,并能够让Multi_User工作,然后重新启动服务。我们让IIS每隔几分钟/秒就会搜索特定的包。
使用主
GO
选择d.s ame, d.s dbid, spid, login_time, nt_domain, nt_username, loginame 从sysprocesses p内部连接sysdatabases d在p.dbid = d.dbid where d.name = '数据库名'
杀死568 -杀死蜘蛛
修改数据库名称
设置MULTI_USER 去