Creo que esto es lo que nos gusta mucho hacer.
--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
Si ya creó un usuario y lo asignó a esa base de datos antes haciendo
USE [yourDB]
CREATE USER hello FOR LOGIN hello WITH DEFAULT_SCHEMA=[dbo]
GO
luego elimínelo amablemente haciendo lo siguiente y siga los pasos
USE yourDB;
GO
DROP USER newlogin;
GO
Para obtener más información, siga los enlaces:
Ocultación bases de datos para un inicio de sesión en Microsoft Sql Server 2008R2 y superior