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:
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
Wesley Mota
Latest posts by Wesley Mota (see all)
- The Ultimate Guide to Gry Online Ruletka - novembro 14, 2024