有时(例如)通过执行以下命令将数据库设置为脱机时,将抛出异常,因为连接了一个或多个客户端:
ALTER DATABASESET OFFLINE
根据这个答案,一个解决方案是with rollback immediate
在最后使用:
ALTER DATABASESET OFFLINE WITH ROLLBACK IMMEDIATE
实际上为什么这会断开其他客户端的连接?这听起来像是一种非常明显的强制断开连接的方式,尽管它有效.
当其他用户在其上运行事务时,您无法使数据库脱机,因此您将不得不以这种或那种方式断开用户以使数据库脱机.
如果您有礼貌,可以要求所有用户在脱机数据库之前完成他们正在做的任何事情
但如果那不合实,包括选项
WITH ROLLBACK IMMEDIATE
表示所有当前事务都回滚(数据库重置为事务启动的点).你也可以用
WITH ROLLBACK AFTER 60 SECONDS
但我从来没有这么做过
如果在未完成的事务正在运行时可以使数据库脱机,则数据库将处于不稳定状态,并且既未进行更改也未取消