Sqlserver
 sql >> Base de Dados >  >> RDS >> Sqlserver

DBA - Como matar todos os processos de banco de dados no SQL Server

O código abaixo pode ser usado para matar todos os processos para o banco de dados SQL Server. O código pode ser usado em situações em que as alterações no banco de dados não podem ser feitas se algum processo estiver sendo executado no banco de dados, como renomear o banco de dados não pode ser feito se algum processo estiver em execução nesse banco de dados.

USE MASTER
GO
DECLARE @DatabaseName AS VARCHAR(500)
-->Provide the DataBaseName for which want to Kill all processes.
SET @DatabaseName='YourDataBaseName'
DECLARE @Spid INT
DECLARE KillProcessCur CURSOR FOR
  SELECT spid
  FROM   sys.sysprocesses
  WHERE  DB_NAME(dbid) = @DatabaseName
OPEN KillProcessCur
FETCH Next FROM KillProcessCur INTO @Spid
WHILE @@FETCH_STATUS = 0
  BEGIN
      DECLARE @SQL VARCHAR(500)=NULL
      SET @SQL='Kill ' + CAST(@Spid AS VARCHAR(5))
      EXEC (@SQL)
      PRINT 'ProcessID =' + CAST(@Spid AS VARCHAR(5))
            + ' killed successfull'
      FETCH Next FROM KillProcessCur INTO @Spid
  END
CLOSE KillProcessCur
DEALLOCATE KillProcessCur