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

Restringir o acesso de login do SQL Server a apenas um banco de dados


Acho que é isso que gostamos muito de fazer.
--Step 1: (create a new user)
create LOGIN hello WITH PASSWORD='foo', CHECK_POLICY = OFF;


-- Step 2:(deny view to any database)
USE master;
GO
DENY VIEW ANY DATABASE TO hello; 


 -- step 3 (then authorized the user for that specific database , you have to use the  master by doing use master as below)
USE master;
GO
ALTER AUTHORIZATION ON DATABASE::yourDB TO hello;
GO

Se você já criou um usuário e atribuiu a esse banco de dados antes, fazendo
USE [yourDB] 
CREATE USER hello FOR LOGIN hello WITH DEFAULT_SCHEMA=[dbo] 
GO

então, por favor, exclua-o fazendo abaixo e siga as etapas
   USE yourDB;
   GO
   DROP USER newlogin;
   GO

Para mais informações siga os links:

Ocultar bancos de dados para um login no Microsoft Sql Server 2008R2 e superior