This is a bit of a drastic script: every now and then I’ll have a misbehaving user or application that will create way too many sessions, causing all sorts of issues. I could kill the sessions one at a time, but that’s such a drag! So let’s terminate those user sessions!
Even inactive sessions can be an issue: For every open session, SQL needs to allocate a bit of RAM and CPU to maintain that connection. If you have a ton of sessions that are just idle, then you could be wasting memory that other sessions could use. This is basically how DDOS attacks work: Overwhelm the server with connections until you run out of resources.
That’s why I created the script below — you give it a user name, and it kills every session associated with the login. You can even filter it down to just one database! Or not, that’s totally your call. All I can tell you is that it does what the name says: it slays all, and that’s just metal.
DECLARE @spids TABLE (pk INT IDENTITY(1,1), spid SMALLINT) DECLARE @i INT = 1 insert INTO @spids(spid) SELECT s.spid FROM sys.sysprocesses s INNER JOIN sys.server_principals p ON s.sid = p.sid WHERE p.name = 'username' --kill all logins for that one user --and DB_NAME(dbid) IN ('dbname') --kill all users in that one database DECLARE @sql VARCHAR(1000) WHILE @i<=(SELECT MAX(pk) FROM @spids) BEGIN SELECT @sql = 'kill '+ CAST(spid AS VARCHAR(100)) FROM @spids WHERE pk = @i PRINT @sql EXEC (@sql) SELECT @i = @i + 1 end
Helpful links
Kill documentation – here