我试图在我的开发数据库上执行一些离线维护(从实时备份恢复开发数据库),但是通过SQL Server Management Studio执行的“脱机”命令执行得非常慢——大约30分钟以上。我只是在我的智慧的尽头,我似乎找不到任何参考网上可能导致速度问题,或如何解决它。
一些站点建议,打开到数据库的连接会导致这种放缓,但使用此数据库的唯一应用程序是我的开发机器的IIS实例,并且服务已停止—没有更多打开的连接。
是什么导致了这种减速,我能做些什么来加速它?
我试图在我的开发数据库上执行一些离线维护(从实时备份恢复开发数据库),但是通过SQL Server Management Studio执行的“脱机”命令执行得非常慢——大约30分钟以上。我只是在我的智慧的尽头,我似乎找不到任何参考网上可能导致速度问题,或如何解决它。
一些站点建议,打开到数据库的连接会导致这种放缓,但使用此数据库的唯一应用程序是我的开发机器的IIS实例,并且服务已停止—没有更多打开的连接。
是什么导致了这种减速,我能做些什么来加速它?
当前回答
经过一些额外的搜索(受到gbn的答案和u07ch对KMike答案的评论启发的新搜索词),我发现了这个,在2秒内成功完成:
ALTER DATABASE <dbname> SET OFFLINE WITH ROLLBACK IMMEDIATE
(更新)
当仍然出现以下错误时,您可以根据这篇博客文章的启发进行修复:
ALTER DATABASE失败,因为无法在数据库'dbname'上放置锁。
您可以运行以下命令来找出谁在锁定您的数据库:
EXEC sp_who2
并使用你在以下命令中找到的任何SPID:
KILL <SPID>
然后再次运行ALTER DATABASE命令。现在应该可以工作了。
其他回答
为了解决这个问题,我停止了在IIS中连接到db的网站,立即“冻结”“使db离线”面板解冻。
关闭SSMS (SQL服务管理器)的实例,从请求解决了我的问题.....
在我的例子中,数据库与旧的Sharepoint安装有关。在服务器管理器中停止和禁用相关服务“解除”已经运行了40分钟的脱机操作,并立即完成。
您可能希望检查当前是否有任何服务正在使用该数据库。
在SSMS中,将数据库设置为只读,然后返回。连接将被关闭,从而释放锁。
在我的例子中,有一个网站打开了到数据库的连接。这个方法很简单:
右键单击数据库-> Properties -> Options “数据库只读”设置为“True” 在弹出的对话框中单击“是”,警告SQL Server将关闭与数据库的所有连接。 重新打开选项并关闭只读 现在尝试重命名数据库或使其脱机。
经过一些额外的搜索(受到gbn的答案和u07ch对KMike答案的评论启发的新搜索词),我发现了这个,在2秒内成功完成:
ALTER DATABASE <dbname> SET OFFLINE WITH ROLLBACK IMMEDIATE
(更新)
当仍然出现以下错误时,您可以根据这篇博客文章的启发进行修复:
ALTER DATABASE失败,因为无法在数据库'dbname'上放置锁。
您可以运行以下命令来找出谁在锁定您的数据库:
EXEC sp_who2
并使用你在以下命令中找到的任何SPID:
KILL <SPID>
然后再次运行ALTER DATABASE命令。现在应该可以工作了。