Limitar conexões de banco de dados simultâneas por conta de usuário do SQL Server

2

Eu gostaria de criar uma conta de usuário do SQL Server 2005, mas limitar esse usuário a permitir apenas que eles tenham duas conexões simultâneas ao banco de dados de uma só vez. Existe alguma maneira de fazer isso através da configuração do SQL Server?

    
por Mindy 04.11.2009 / 01:02

1 resposta

8

Você pode tentar os acionadores de login: link

O TechNet sugere que:

You can use logon triggers to audit and control server sessions, such as by tracking login activity, restricting logins to SQL Server, or limiting the number of sessions for a specific login.

O primeiro exemplo de código limita um usuário a 3 conexões (citando o TechNet):

USE master;
GO

CREATE LOGIN login_test WITH PASSWORD = '3KHJ6dhx(0xVYsdf' MUST_CHANGE,
    CHECK_EXPIRATION = ON;
GO

GRANT VIEW SERVER STATE TO login_test;
GO

CREATE TRIGGER connection_limit_trigger
ON ALL SERVER WITH EXECUTE AS 'login_test'
FOR LOGON
AS
BEGIN
IF ORIGINAL_LOGIN()= 'login_test' AND
    (SELECT COUNT(*) FROM sys.dm_exec_sessions
            WHERE is_user_process = 1 AND
                original_login_name = 'login_test') > 3
    ROLLBACK;
END;
    
por 04.11.2009 / 01:25