还原数据库提示“ 因为数据库正在使用,所以无法获得对数据库的独占访问权“

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/a1871837908/article/details/50952167

1,利用SQL语句,杀死正在使用该数据库的所有进程,自己以前在做一个SQL SERVER操作小工具的时候有写过该功能的SQL,贴出来供大家参考:
declare @dbname varchar(50)
set @dbname=’数据库名称’
declare @sql varchar(50)
declare cs_result cursor local for select ‘kill ‘+cast(spid as varchar(50)) from sys.sysprocesses where db_name(dbid)=@dbname
open cs_result
fetch next from cs_result into @sql
while @@fetch_status=0
begin
execute(@sql)
fetch next from cs_result into @sql
end
close cs_result
deallocate cs_result

该SQL语句利用游标循环所有正在使用该数据库的进程,并通过kill命令杀死进程。

2,利用SQL语句,断开所有用户链接,并回滚所有事务,具体SQL语句如下:
ALTER DATABASE [数据库名称]
SET OFFLINE WITH ROLLBACK IMMEDIATE

展开阅读全文

没有更多推荐了,返回首页