Esta página explica como acessar um banco de dados do Spanner quando você é um usuário de controle de acesso detalhado.
Para saber mais sobre o controle de acesso detalhado, consulte Sobre o controle de acesso detalhado.
Como usuário de controle de acesso minucioso, você precisa selecionar uma função de banco de dados para usar ao executar instruções e consultas SQL e realizar operações de linha em um banco de dados. Sua seleção de função persiste durante a sessão até que você mude a função.
Quando você envia uma consulta, DML ou operação de linha, o Spanner verifica a autorização usando as seguintes regras:
- Google Cloud console
O Spanner primeiro verifica se você tem permissões do IAM no nível do banco de dados. Nesse caso, o console do Google Cloud não mostra um seletor de função do banco de dados, e a sessão continua com suas permissões no nível do banco de dados.
Se você tiver apenas privilégios de controle de acesso detalhado e nenhuma permissão no nível do banco de dados do IAM, será necessário ter acesso ao papel do sistema
spanner_sys_reader
ou a um dos papéis de membro dele. Selecione uma função na página Visão geral do banco de dados para que sua sessão de console do Google Cloud prossiga com os privilégios necessários.
- SDK do Google Cloud
Se você especificar uma função de banco de dados ao enviar uma consulta, DML ou uma operação de linha, o Spanner vai verificar os privilégios de controle de acesso detalhado. Se a verificação falhar, o Spanner não vai verificar as permissões do IAM no nível do banco de dados, e a operação vai falhar.
Se você não especificar um papel de banco de dados, o Spanner vai verificar as permissões do IAM no nível do banco de dados. Se as verificações forem bem-sucedidas, a sessão vai continuar com as permissões no nível do banco de dados.
Use estes métodos para especificar um papel do banco de dados ao acessar um banco de dados do Spanner:
Console
Selecione um banco de dados e, na página Visão geral do banco de dados, clique no ícone Alterar função do banco de dados (lápis) ao lado do campo Função atual.
Por padrão, quando um usuário de controle de acesso granular faz login, esse campo tem o valor
public
. Para informações sobre o papel do sistemapublic
, consulte Papéis do sistema de controle de acesso detalhado.Na caixa de diálogo Change database role, selecione outro papel na lista de papéis disponíveis.
Clique em Atualizar.
O campo Papel atual mostra o novo papel.
gcloud
Adicione a opção
--database-role
ao comandogcloud spanner databases execute-sql
da seguinte maneira:gcloud spanner databases execute-sql DATABASE_NAME \ --instance=INSTANCE_NAME \ --sql="SELECT * from TABLE_NAME;" \ --database-role=ROLE_NAME
Bibliotecas de cliente
C++
C#
Go
Java
Node.js
PHP
Python
Ruby