Dicas SQL Server

Descobrir privilégios em objetos no banco de dados

Saiba como descobrir privilégios em objetos um usuário tem no banco de dados.

Saiba como descobrir privilégios em objetos um usuário tem no banco de dados
Saiba como descobrir privilégios em objetos um usuário tem no banco de dados

Olá pessoal, bom dia tudo bem? Gostaria de compartilhar com vocês mais um post sobre os privilégios que um determinado usuário tem em objetos no banco de dados.
Recentemente fiz uma atividade em que era necessário a verificação de quais privilégios alguns usuários tinham no banco de dados.

Se tinha privilégios e quais tinham e em quais objetos. Olhando algumas dmvs é possível encontrar na view database_permissions muitas informações a respeito. Utilizei a procedure sp_MSforeachdb para executar em cada banco de dados, facilitando assim as informações que o cliente precisava.
O resultado fica da seguinte forma:

Privilégios em objetos SQL Server
Privilégios em objetos SQL Server

Abaixo vou deixar a vocês o código utilizado. Esperem que seja útil a vocês. Um grande abraço!

DECLARE @command varchar(1000) 
SELECT @command = 'USE ? 
SELECT DB_NAME() as NomeDoBanco
   , sys.schemas.name ''Schema''
   , sys.objects.name NomeDoObjeto
   , sys.database_principals.name Usuario
   , sys.database_permissions.type TipoPermissao
   ,     sys.database_permissions.permission_name as NomeDaPermissao
   ,      sys.database_permissions.state as EstadoDaPermissao
   ,     sys.database_permissions.state_desc as DescricaoEst
   ,     state_desc + '' '' + permission_name + '' on [''+ sys.schemas.name + ''].['' + sys.objects.name + ''] to ['' + sys.database_principals.name + '']'' COLLATE LATIN1_General_CI_AS ''CodigoGrant''
from sys.database_permissions 
join sys.objects 
on sys.database_permissions.major_id = sys.objects.object_id 
join sys.schemas 
on sys.objects.schema_id = sys.schemas.schema_id 
join sys.database_principals 
on sys.database_permissions.grantee_principal_id = sys.database_principals.principal_id 
order by 1, 3'

EXEC sp_MSforeachdb @command

 

Se você está com problemas de performance e procura uma consultoria para resolver a perfomance no seu banco de dados, acesse: Consultoria DBA SQL Server

 

Descobrir privilégios em objetos no banco de dados
The following two tabs change content below.

Wesley Mota

DBA SQL Server
Profissional graduado em Banco de Dados e Sistemas de Informação com mais de 7 anos de experiência em empresas de software. Certificado MCSA Microsoft SQL Server possui intensa vivência em administração de banco de dados, Tunning, Performance SQL Server, levantamento de melhorias e monitoramento de banco de dados e servidores SQL Server. Consultoria SQL Server em diversos clientes no Brasil e ao redor do mundo. Escritor no blog dbasqlserverbr.com.br/blog. Onde compartilha conhecimento, experiências e dicas de performance para DBAs SQL Server. Conhecimentos em Oracle e ambientes de alta disponibilidade. Desenvolvimento de softwares web e mobile.Gerenciamento de equipe e projetos.