sqlserver: 查看并关闭到数据库的连接
环境:window 10 x64 专业sqlserver 2014 x64如何查看到某个数据库的连接?在master数据库的视图sysprocesses记录着所有有效的连接。我们可以使用如下命令查看到test2数据库的连接:select spid,* from sysprocesses where dbid=DB_ID('test2')查询结果如下图:数据库连接的唯一标志?每个数据库连接都有一个唯
·
环境:
- 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'
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
已为社区贡献20条内容
所有评论(0)