代码改变世界

SQL Server 中断开连接到指定数据库的所有连接

  BIWORK  阅读(1806)  评论(0编辑  收藏  举报

常用的情形是在部署测试数据库时需要通过SQL代码自动重新创建数据库,在删除的时候往往会发生错误,错误信息一般会指出目前有用户连接到这个数据库上,因此不能删除.

 

实现的方式是通过查询指定数据库中活跃的 SPID, 然后一一删除.

 

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO

USE MASTER
GO

IF OBJECT_ID('dbo.USP_KillSPID','P')IS NOT NULL
DROP PROCEDURE dbo.USP_KillSPID
GO

CREATE PROCEDURE dbo.USP_KillSPID
@DatabaseName VARCHAR(255)
AS

DECLARE @SPID NVARCHAR(255)
DECLARE curDBLogin CURSOR FOR
SELECT CAST(SPID AS VARCHAR(255)) AS SPID
FROM MASTER..sysprocesses
WHERE dbid = DB_ID(@DatabaseName)

OPEN curDBLogin
FETCH NEXT FROM curDBLogin INTO @SPID

WHILE @@FETCH_STATUS = 0
   BEGIN
      IF @SPID <> @@SPID
          EXEC('KILL '+ @SPID )
      FETCH NEXT FROM curDBLogin INTO @SPID
   END

CLOSE curDBLogin
DEALLOCATE curDBLogin
GO

-- Kill logins of database
EXEC dbo.USP_KillSPID 'CommonControlDB' 

-- Drop itself
DROP PROCEDURE dbo.USP_KillSPID

 

 

编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 单线程的Redis速度为什么快?
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 展开说说关于C#中ORM框架的用法!
· SQL Server 2025 AI相关能力初探
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
点击右上角即可分享
微信分享提示