国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > 綜合 > 正文

使用T-SQL強制所有用戶退出當前數據庫

2024-07-21 02:44:10
字體:
來源:轉載
供稿:網友

目的:強制所有用戶退出當前服務器。


描述:該代碼終止數據庫的所有用戶進程. 用戶進程是 sp_who, 或者 sp_who2, SPID > 50 返回的所有進程. 代碼使用 sp_who (不牽扯任何系統表)查找運行在當前數據庫上的進程, 并通過使用 KILL <進程號> 終止進程..


用戶可以指定 @MaxAttemptsToKillEachUserPRocess 變量(嘗試終止單個進程的次數, 默認值 3). 如果超過最大值, 代碼將返回一個錯誤 (例如, 進程不能被終止).


結果集: NA


結果集排序: NA


使用的 TABLES/VIEWS: NA


REVISIONS


DATE DEVELOPER DESCRipTION OF REVISION VERSION

========= =============== ================================= ===========

05/05/2005 Omri Bahat Initial release 1.00


==================================================================================

Copyright ?SQL Farms Solutions, www.sqlfarms.com. All rights reserved.

This code may be used at no charge as long as this copyright notice is not removed.

==================================================================================*/


DECLARE @MaxAttemptsToKillEachUserProcess INT

DECLARE @CurrentAttempts INT

DECLARE @ServerName NVARCHAR(128)

DECLARE @DatabaseName NVARCHAR(128)

DECLARE @SQLCommand NVARCHAR(128)

DECLARE @SPID INT

DECLARE @LoginName NVARCHAR(128)


SET NOCOUNT ON


SET @MaxAttemptsToKillEachUserProcess = 3


-- 得到服務器和數據庫名稱

SET @ServerName = CAST(ISNULL(SERVERPROPERTY('ServerName'), 'Unknown') AS SYSNAME)


-- 該表記錄用戶進程標識.

IF OBJECT_ID('tempdb..#tblUserProcesses', 'U') IS NOT NULL

DROP TABLE #tblUserProcesses


CREATE TABLE #tblUserProcesses (

SPID INT,

ECID INT,

Status NVARCHAR(256),

LoginName NVARCHAR(128),

HostName NVARCHAR(128),

BlockedBy NVARCHAR(128),

DatabaseName NVARCHAR(128),

Command NVARCHAR(256))


INSERT INTO #tblUserProcesses

EXEC SP_WHO


DELETE FROM #tblUserProcesses

WHERE SPID <= 50 OR SPID = @@SPID


WHILE EXISTS(SELECT * FROM #tblUserProcesses WITH (NOLOCK))

BEGIN

SET @SQLCommand = NULL

SET @SPID = NULL

SET @LoginName = NULL

SET @DatabaseName = NULL

SELECT TOP 1 @SQLCommand = 'KILL ' + CAST(SPID AS NVARCHAR(32)),

@SPID = SPID,

@LoginName = ISNULL(LoginName, 'NA'),

@DatabaseName = DatabaseName

FROM #tblUserProcesses WITH (NOLOCK)


SET @CurrentAttempts = 0


WHILE @CurrentAttempts <= @MaxAttemptsToKillEachUserProcess

BEGIN

EXEC(@SQLCommand)


IF @@ERROR <> 0

BEGIN

PRINT(N'Error killing process ' + CAST(@SPID AS VARCHAR(32)) + N', of login ' + @LoginName

+ N', on database ' + @DatabaseName

+ N'. The process was probably terminated by the user.')


BREAK

END


-- 清除必要的表

WAITFOR DELAY '00:00:03'


-- 確認進程真正終止

INSERT INTO #tblUserProcesses

EXEC SP_WHO @SPID


IF @@ROWCOUNT = 0

BREAK

ELSE

SET @CurrentAttempts = @CurrentAttempts + 1

END


IF @CurrentAttempts > @MaxAttemptsToKillEachUserProcess

BEGIN

PRINT(N'The number of attempts to kill process ' + CAST(@SPID AS VARCHAR(32)) + N', of login ' + @LoginName

+ N', on database ' + @DatabaseName + N' exceeded the maximum number of retry attempts. Script is aborting.')


RETURN

END


DELETE FROM #tblUserProcesses


INSERT INTO #tblUserProcesses

EXEC SP_WHO


DELETE FROM #tblUserProcesses

WHERE SPID <= 50 OR SPID = @@SPID

END

GO


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 当涂县| 九寨沟县| 清水河县| 平凉市| 会理县| 奎屯市| 手游| 沧州市| 南岸区| 安阳县| 吉水县| 湘阴县| 贞丰县| 格尔木市| 恭城| 锡林郭勒盟| 德令哈市| 广水市| 武平县| 临海市| 满城县| 藁城市| 菏泽市| 彭阳县| 乌兰浩特市| 石泉县| 甘肃省| 开化县| 普陀区| 永丰县| 衡阳县| 惠来县| 东莞市| 凌源市| 佳木斯市| 成安县| 永宁县| 青田县| 仪征市| 蒙山县| 蓬莱市|