Sqlserver
 sql >> Database >  >> RDS >> Sqlserver

DBA - Come eliminare tutti i processi di database su SQL Server

Il codice seguente può essere usato per terminare tutti i processi nel database di SQL Server. Il codice può essere utilizzato in situazioni in cui non è possibile apportare modifiche al database se un processo è in esecuzione sul database, ad esempio rinominare il database non può essere eseguito se un processo è in esecuzione su quel database.

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