--但是这用到项目中数据库正在使用的话是不成功的 ,它具有排它性 !
--所以我写了一个存储过程来解决,这也是很多程序员花了很久才解决的问题
--代码用法如下 :有附带的例子下载
--创建存储过程 killspid
create proc killspid (@dbname varchar(20))
as
begin
declare @sql nvarchar(500)
declare @spid int
set @sql='declare getspid cursor for
select spid from sysprocesses where dbid=db_id('''+@dbname+''')'
exec (@sql)
open getspid
fetch next from getspid into @spid
while @@fetch_status < >-1
begin
exec('kill '+@spid)
fetch next from getspid into @spid
end
close getspid
deallocate getspid
end
GO
--说明:
--1.此存储过程应写在Master中;
--2.以上代码就是解决因为数据库正在使用,所以未能获得对数据库的排它访问权的问题,不然系统有时会报错;
我附带一个简单的备份还原的例子 (ASP.NET +SQL SERVER 2005 的运行环境)