sqlserver: 查看并关闭到数据库的连接

本文详细介绍了在SQL Server环境中如何查看、标识和管理数据库连接,包括使用SPID作为唯一标志,以及通过SQL命令和存储过程批量关闭指定数据库的所有连接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

环境:

  • window 10 x64 专业
  • sqlserver 2014 x64

如何查看到某个数据库的连接?

在master数据库的视图sysprocesses记录着所有有效的连接。
在这里插入图片描述
我们可以使用如下命令查看到test2数据库的连接:

select spid,* from sysprocesses where dbid=DB_ID('test2')

查询结果如下图:
在这里插入图片描述

数据库连接的唯一标志?

每个数据库连接都有一个唯一的标志,它就是spid,在上面的查询结果中,我们可以看到。

怎么查看当前连接的spid?

使用下面的sql:

select @@spid

查询结果如下图:
在这里插入图片描述

如何关闭指定的连接?

找到数据库连接spid,然后执行kill spid,如下面的语句:

kill 51

执行完后,你就发现那个链接已经中断了。

如何批量关闭所有的指定数据库的所有连接(注意:如果连接到数据库test2,然后执行杀死所有到数据库test2的连接,那么不能杀死当前的连接)?

我们可以使用如下存储过程:

create proc usp_killconnect(@dbname varchar(20))
as
begin
declare @sql nvarchar(500),@temp varchar(1000)
declare @spid int
set @sql='declare getspid cursor for  
select spid from sysprocesses where dbid=db_id('''+@dbname+''') and spid > 50 and spid <> @@spid'
exec (@sql)
open getspid
fetch next from getspid into @spid
while @@fetch_status<>-1
begin
 set @temp='kill '+rtrim(@spid)
 exec(@temp)
fetch next from getspid into @spid
end
close getspid
deallocate getspid
end

使用时:

exec usp_killconnect 'test2'
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jackletter

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值