SQLServer 查询当前数据库连接并清除未关闭的连接

最近在优化公司的商城项目,从最开始的单站点,到现在的站点负载+服务负载。性能提高不少,但是新的问题暴露了,在以前的代码中居然存在ADO.NET和Dapper共用数据库连接的情况。导致数据库一直提示连接池达到最大限度报错。查了代码发现是代码中存在ADO.NET进行了连接的Open,给Dapper使用但并没有释放的BUG(填坑的苦谁人懂)。代码优化好了,但是数据库中还存在一大堆连接没有释放怎么办呢? 于是翻阅了一下知识的海洋,找到了以下代码,查询并清空所有的数据库连接:
[sql title=”查询数据库实例的所有连接”]select * from master.dbo.sysprocesses where dbid = DB_ID(‘DBName’)[/sql]
[sql title=”清除指定实例的所有数据库连接”]USE master
go

declare @programName nvarchar(200),
@spid nvarchar(20)

declare cDblogin cursor for
select cast(spid as varchar(20)) AS spid from master..sysprocesses where dbid=db_id(‘db_id_demo’)
open cDblogin
fetch next from cDblogin into @spid
while @@fetch_status=0
begin
–防止自己终止自己的进程
–否则会报错不能用KILL 来终止您自己的进程
IF @spid <> @@SPID
exec( ‘kill ‘+@spid)
fetch next from cDblogin into @spid
end
close cDblogin
deallocate cDblogin[/sql]

本博客所有文章如无特别注明均为原创

如果觉得对你有帮助,可以通过下方打赏对作者表示鼓励

本文采用知识共享署名-非商业性使用-相同方式共享

如若转载,请注明出处:https://www.fangsi.net/1539.html

(10)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2019年3月18日 19:34
下一篇 2019年3月31日 20:06

相关推荐

发表评论

登录后才能评论