由于活动连接,我的SQL Server 2005无法还原备份。我怎么强迫它?
答案 0 :(得分:185)
您希望将数据库设置为单用户模式,执行还原,然后将其设置回多用户:
ALTER DATABASE YourDB
SET SINGLE_USER WITH
ROLLBACK AFTER 60 --this will give your current connections 60 seconds to complete
--Do Actual Restore
RESTORE DATABASE YourDB
FROM DISK = 'D:\BackUp\YourBaackUpFile.bak'
WITH MOVE 'YourMDFLogicalName' TO 'D:\Data\YourMDFFile.mdf',
MOVE 'YourLDFLogicalName' TO 'D:\Data\YourLDFFile.ldf'
/*If there is no error in statement before database will be in multiuser
mode. If error occurs please execute following command it will convert
database in multi user.*/
ALTER DATABASE YourDB SET MULTI_USER
GO
参考:Pinal Dave(http://blog.SQLAuthority.com)
答案 1 :(得分:172)
右键单击数据库并单击Tasks
然后单击Detach Database
,会弹出一个包含活动连接的对话框。
通过单击“消息”下的超链接,您可以终止活动连接。
然后,您可以在不分离数据库的情况下终止这些连接。
更多信息here。
SQL Server Management Studio 2008的界面已更改,以下是步骤(通过:Tim Leung)
答案 2 :(得分:38)
此代码对我有用,它会杀死数据库的所有现有连接。 您所要做的就是更改行@dbname ='databaseName',使其具有您的数据库名称。
Use Master
Go
Declare @dbname sysname
Set @dbname = 'databaseName'
Declare @spid int
Select @spid = min(spid) from master.dbo.sysprocesses
where dbid = db_id(@dbname)
While @spid Is Not Null
Begin
Execute ('Kill ' + @spid)
Select @spid = min(spid) from master.dbo.sysprocesses
where dbid = db_id(@dbname) and spid > @spid
End
之后我能够恢复它
答案 3 :(得分:5)
重新启动SQL Server将断开用户连接。我找到的最简单的方法 - 如果您想让服务器脱机也很好。
但是出于一些非常奇怪的原因,“Take Offline”选项不能可靠地执行此操作,并且可能会挂起或混淆管理控制台。重新启动然后离线工作
有时这是一个选项 - 例如,如果你已经停止了作为连接源的网络服务器。
答案 4 :(得分:4)
试试这个......
DECLARE UserCursor CURSOR LOCAL FAST_FORWARD FOR
SELECT
spid
FROM
master.dbo.sysprocesses
WHERE DB_NAME(dbid) = 'dbname'--replace the dbname with your database
DECLARE @spid SMALLINT
DECLARE @SQLCommand VARCHAR(300)
OPEN UserCursor
FETCH NEXT FROM UserCursor INTO
@spid
WHILE @@FETCH_STATUS = 0
BEGIN
SET @SQLCommand = 'KILL ' + CAST(@spid AS VARCHAR)
EXECUTE(@SQLCommand)
FETCH NEXT FROM UserCursor INTO
@spid
END
CLOSE UserCursor
DEALLOCATE UserCursor
GO
答案 5 :(得分:2)
这些都不适合我,无法删除或断开当前用户。也看不到与DB的任何活动连接。重新启动SQL Server(右键单击并选择“重新启动”)允许我这样做。
答案 6 :(得分:2)
要添加已经提供的建议,如果您有通过IIS运行的Web应用程序使用该数据库,您可能还需要在还原时停止(不回收)该应用程序的应用程序池,然后重新开始。停止应用程序池会终止活动的http连接并且不再允许,否则最终会允许触发连接并因此锁定数据库的进程。这是一个已知问题,例如在恢复其数据库时使用Umbraco内容管理系统
答案 7 :(得分:2)
我在SQL Server 2008中自动执行还原进程时遇到了这个问题。 我的(成功)方法是两个答案的混合。
首先,我遍历所述数据库的所有连接,然后杀死它们。
DECLARE @SPID int = (SELECT TOP 1 SPID FROM sys.sysprocess WHERE dbid = db_id('dbName'))
While @spid Is Not Null
Begin
Execute ('Kill ' + @spid)
Select @spid = top 1 spid from master.dbo.sysprocesses
where dbid = db_id('dbName')
End
然后,我将数据库设置为single_user模式
ALTER DATABASE dbName SET SINGLE_USER
然后,我运行恢复...
RESTORE DATABASE and whatnot
再次杀死连接
(same query as above)
并将数据库设置回multi_user。
ALTER DATABASE dbName SET MULTI_USER
这样,我确保在设置为单一模式之前没有连接来阻止数据库,因为如果存在,前者将冻结。
答案 8 :(得分:1)
以上都不适合我。我的数据库没有使用Activity Monitor或sp_who显示任何活动连接。我最终不得不:
不是最优雅的解决方案,但它有效,并且它不需要重新启动SQL Server(对我来说不是一个选项,因为数据库服务器托管了许多其他数据库)
答案 9 :(得分:0)
我喜欢这样,
更改数据库离线设置并立即回滚
,然后还原您的数据库。 之后,
更改数据库在线设置并立即回滚