Nesta página, você vai aprender a criar e gerenciar bancos de dados do Spanner:
- Vários métodos para criar um banco de dados
- Modificar opções de banco de dados
- Excluir um banco de dados
Esta página tem informações para bancos de dados com dialeto GoogleSQL e PostgreSQL. Para saber como atualizar um esquema de banco de dados, consulte Fazer atualizações no esquema. Para mais informações sobre como criar uma instância, consulte Criar e gerenciar instâncias. É possível criar um banco de dados em uma instância existente de uma das seguintes maneiras:
- Criar um banco de dados: é possível criar um banco de dados selecionando o dialeto SQL e definindo o esquema.
- Importar seus próprios dados: é possível importar um arquivo CSV, um despejo do MySQL ou do PostgreSQL para um banco de dados novo ou existente.
- Criar um banco de dados com dados de amostra: você pode preencher um banco de dados usando um dos conjuntos de dados de amostra disponíveis para testar os recursos do Spanner.
Criar um banco de dados
É possível criar um banco de dados em uma instância atual. Para bancos de dados do dialeto GoogleSQL, é possível definir o esquema no momento da criação ou depois. Para bancos de dados com dialeto PostgreSQL, é necessário definir o esquema após a criação.
Os esquemas são definidos usando a linguagem de definição de banco de dados, que está documentada para GoogleSQL e PostgreSQL. Consulte os links a seguir para mais informações sobre como criar e atualizar esquemas:
Depois de criar o banco de dados, é possível proteger os bancos de dados importantes para seus aplicativos e serviços ativando a proteção contra exclusão. Para mais informações, consulte Evitar a exclusão acidental de bancos de dados.
Console do Google Cloud
No console Google Cloud , acesse a página Instâncias do Spanner.
Selecione a instância em que você quer criar o banco de dados.
Clique em Criar banco de dados.
Digite os seguintes valores:
- Um nome de banco de dados a ser exibido no console Google Cloud .
- O dialeto a ser usado para este banco de dados.
- Para bancos de dados do dialeto GoogleSQL, forneça um conjunto de instruções DDL que definem seu esquema. Use os modelos de DDL para preencher elementos comuns. Se houver erros nas instruções DDL, o console Google Cloud vai retornar um erro quando você tentar criar o banco de dados.
- Se quiser, selecione uma chave de criptografia gerenciada pelo cliente para usar neste banco de dados.
Clique em Criar para criar o banco de dados.
gcloud
Use o comando gcloud spanner databases create
.
```sh
gcloud spanner databases create DATABASE \
--instance=INSTANCE \
[--async] \
[--database-dialect=DATABASE_DIALECT] \
[--ddl=DDL] \
[--ddl-file=DDL_FILE] \
[--kms-key=KMS_KEY : --kms-keyring=KMS_KEYRING --kms-location=KMS_LOCATION --kms-project=KMS_PROJECT] \
[GCLOUD_WIDE_FLAG …]
```
As seguintes opções são obrigatórias:
DATABASE
- ID do banco de dados ou identificador totalmente qualificado do
banco de dados. Se você especificar o identificador totalmente qualificado, a flag
--instance
poderá ser omitida. --instance=INSTANCE
- A instância do Spanner para o banco de dados.
As seguintes opções são opcionais:
--async
- Retorna imediatamente, sem aguardar a conclusão da operação em andamento.
--database-dialect=DATABASE_DIALECT
- O dialeto SQL do banco de dados do Spanner. Precisa ser uma destas opções:
POSTGRESQL
ouGOOGLE_STANDARD_SQL
. --ddl=DDL
- Instruções DDL (linguagem de definição de dados) separadas por ponto e vírgula para execução
no banco de dados recém-criado. Se houver um erro em alguma
instrução, o banco de dados não será criado. Essa flag será ignorada se
--ddl_file
estiver definida. Não é compatível com bancos de dados de dialeto PostgreSQL. --ddl-file=DDL_FILE
- Caminho de um arquivo que contém instruções DDL (linguagem de definição de dados) separadas por ponto e vírgula para serem executadas no banco de dados recém-criado. Se houver um erro em alguma instrução, o banco de dados não será criado. Se
--ddl_file
estiver definido,--ddl
será ignorado. Não é compatível com bancos de dados de dialeto PostgreSQL.
Se você estiver especificando uma chave do Cloud Key Management Service para usar ao criar o banco de dados, inclua as seguintes opções:
--kms-key=KMS_KEY
- ID da chave ou identificador totalmente qualificado da chave.
Essa flag precisa ser especificada se algum dos outros argumentos neste grupo for especificado. Os outros argumentos podem ser omitidos se o identificador totalmente qualificado for fornecido.
--kms-keyring=KMS_KEYRING
- ID do keyring da chave do Cloud KMS.
--kms-location=KMS_LOCATION
- Google Cloud localização da chave.
--kms-project=KMS_PROJECT
- Google Cloud ID do projeto da chave.
Cliente (GoogleSQL)
C++
Para saber como instalar e usar a biblioteca de cliente do Spanner, consulte Bibliotecas de cliente do Spanner.
Para autenticar no Spanner, configure o Application Default Credentials. Para mais informações, consulte Configurar a autenticação para um ambiente de desenvolvimento local.
Go
Para saber como instalar e usar a biblioteca de cliente do Spanner, consulte Bibliotecas de cliente do Spanner.
Para autenticar no Spanner, configure o Application Default Credentials. Para mais informações, consulte Configurar a autenticação para um ambiente de desenvolvimento local.
Java
Para saber como instalar e usar a biblioteca de cliente do Spanner, consulte Bibliotecas de cliente do Spanner.
Para autenticar no Spanner, configure o Application Default Credentials. Para mais informações, consulte Configurar a autenticação para um ambiente de desenvolvimento local.
Node.js
Para saber como instalar e usar a biblioteca de cliente do Spanner, consulte Bibliotecas de cliente do Spanner.
Para autenticar no Spanner, configure o Application Default Credentials. Para mais informações, consulte Configurar a autenticação para um ambiente de desenvolvimento local.
PHP
Para saber como instalar e usar a biblioteca de cliente do Spanner, consulte Bibliotecas de cliente do Spanner.
Para autenticar no Spanner, configure o Application Default Credentials. Para mais informações, consulte Configurar a autenticação para um ambiente de desenvolvimento local.
Python
Para saber como instalar e usar a biblioteca de cliente do Spanner, consulte Bibliotecas de cliente do Spanner.
Para autenticar no Spanner, configure o Application Default Credentials. Para mais informações, consulte Configurar a autenticação para um ambiente de desenvolvimento local.
Ruby
Para saber como instalar e usar a biblioteca de cliente do Spanner, consulte Bibliotecas de cliente do Spanner.
Para autenticar no Spanner, configure o Application Default Credentials. Para mais informações, consulte Configurar a autenticação para um ambiente de desenvolvimento local.
Importe seus próprios dados
É possível importar seus próprios dados para um banco de dados do Spanner usando um arquivo CSV, um arquivo de despejo do MySQL ou um arquivo de despejo do PostgreSQL. É possível fazer upload de um arquivo local usando o Cloud Storage ou diretamente de um bucket do Cloud Storage. O upload de um arquivo local usando o Cloud Storage pode gerar cobranças.
Se você escolher usar um arquivo CSV, também será necessário fazer upload de um arquivo JSON separado que contenha o esquema do banco de dados.
Console do Google Cloud
No console Google Cloud , acesse a página Instâncias do Spanner.
Selecione a instância em que você quer criar o banco de dados.
Clique em Importar meus dados.
Digite os seguintes valores:
Selecione o Tipo de arquivo.
Faça upload do arquivo do seu computador ou selecione um caminho de bucket do Cloud Storage para o arquivo.
(Opcional) Se você escolher usar um arquivo CSV, também será necessário fazer upload de um arquivo JSON separado que contenha o esquema do banco de dados. O arquivo JSON precisa usar a seguinte estrutura para definir o esquema:
{ "name": "COLUMN_NAME", "type": "TYPE", "notNull": NOT_NULL_VALUE, "primaryKeyOrder": PRIMARY_KEY_ORDER }
Substitua:
COLUMN_NAME: o nome da coluna na tabela.
TYPE: o tipo de dados da coluna.
(Opcional) NOT_NULL_VALUE: indica se a coluna pode armazenar valores nulos ou não. As entradas válidas são
true
oufalse
. O padrão éfalse
.(Opcional): PRIMARY_KEY_ORDER: determina a ordem da chave primária. Defina o valor como
0
para uma coluna de chave não primária. Defina o valor como um número inteiro, por exemplo,1
para uma coluna de chave primária. Colunas com números menores aparecem antes em uma chave primária composta.
Por padrão, o arquivo CSV espera uma vírgula para o delimitador de campo e uma nova linha para o delimitador de linha. Para mais informações sobre como usar delimitadores personalizados, consulte a referência
gcloud alpha spanner databases import
.Selecione um banco de dados novo ou existente como destino.
Clique em Importar.
O Spanner abre o Cloud Shell e preenche um comando que instala a ferramenta de migração do Spanner e executa o comando
gcloud alpha spanner databases import
. Pressione a teclaENTER
para importar dados para seu banco de dados.x
Usar um conjunto de dados de amostra
É possível preencher novos bancos de dados em uma instância atual com conjuntos de dados de amostra que ajudam a conhecer os recursos do Spanner, como o modelo relacional, a pesquisa de texto completo ou a pesquisa vetorial.
Console do Google Cloud
No console Google Cloud , acesse a página Instâncias do Spanner.
Selecione a instância em que você quer criar o banco de dados.
Clique em Explorar conjuntos de dados.
Selecione um dos seguintes conjuntos de dados:
- Gráfico de finanças: use esse conjunto de dados para conhecer os recursos de gráfico do Spanner.
- Banco on-line: use este conjunto de dados para conhecer os recursos de pesquisa de texto completo do Spanner.
- Jogos on-line: use este conjunto de dados para conhecer os recursos de banco de dados relacional do Spanner.
- Varejo: use esse conjunto de dados para conhecer os recursos de gráfico e pesquisa de texto completo do Spanner.
Clique em Criar banco de dados.
Atualizar o esquema ou as opções do banco de dados
É possível atualizar o esquema e as opções do banco de dados usando instruções DDL.
Por exemplo, para adicionar uma coluna a uma tabela, use a seguinte instrução DDL:
GoogleSQL
ALTER TABLE Songwriters ADD COLUMN Publisher STRING(10);
PostgreSQL
ALTER TABLE Songwriters ADD COLUMN Publisher VARCHAR(10);
Para atualizar a versão do otimizador de consultas, use a seguinte instrução DDL:
GoogleSQL
ALTER DATABASE Music SET OPTIONS(optimizer_version=null);
PostgreSQL
ALTER DATABASE DB-NAME SET spanner.optimizer_version TO DEFAULT;
Para mais informações sobre as opções compatíveis, consulte a referência de DDL ALTER DATABASE
para GoogleSQL ou PostgreSQL.
Para informações sobre atualizações de esquema, consulte Fazer atualizações de esquema.
Console do Google Cloud
No console Google Cloud , acesse a página Instâncias do Spanner.
Selecione a instância que contém o banco de dados a ser alterado.
Selecione o banco de dados.
Clique em Spanner Studio.
Clique em
Nova guia ou use a guia do editor vazia. Em seguida, insira as instruções DDL a serem aplicadas.Clique em Executar para aplicar as atualizações. Se houver erros na DDL, o console Google Cloud vai retornar um erro e o banco de dados não será alterado.
gcloud
Para alterar um banco de dados com a ferramenta de linha de comando gcloud
, use
gcloud spanner databases ddl update
.
gcloud spanner databases ddl update \ (DATABASE : --instance=INSTANCE) \ [--async] \ [--ddl=DDL] \ [--ddl-file=DDL_FILE] \
Consulte a
referência de gcloud
para
detalhes sobre as opções disponíveis.
Transmita as atualizações do banco de dados para o comando com a flag --ddl
ou --ddl-file
. Se um arquivo DDL for especificado, a flag --ddl
será ignorada.
Consulte a referência de DDL ALTER DATABASE
para GoogleSQL ou PostgreSQL para ver as instruções de DDL a serem incluídas.
DDL
Consulte a referência de DDL do ALTER DATABASE
para GoogleSQL ou PostgreSQL para mais detalhes.
Verificar o progresso das operações de atualização de esquema
Console do Google Cloud
No menu de navegação do Spanner, selecione a guia Operações. A página Operações mostra uma lista de operações ativas em execução.
Encontre a operação de esquema na lista. Se ainda estiver em execução, a barra de progresso na coluna Horário de término vai mostrar a porcentagem da operação concluída, conforme mostrado na imagem a seguir:
gcloud
Use gcloud spanner operations describe
para verificar o progresso de uma operação.
Consiga o ID da operação:
gcloud spanner operations list --instance=INSTANCE-NAME \ --database=DATABASE-NAME --type=DATABASE_UPDATE_DDL
Substitua:
- INSTANCE-NAME com o nome da instância do Spanner.
- DATABASE-NAME pelo nome do banco de dados.
Execute
gcloud spanner operations describe
:gcloud spanner operations describe OPERATION_ID\ --instance=INSTANCE-NAME \ --database=DATABASE-NAME
Substitua:
- OPERATION-ID: o ID da operação que você quer verificar.
- INSTANCE-NAME: o nome da instância do Spanner.
- DATABASE-NAME: o nome do banco de dados do Spanner.
A seção
progress
na saída mostra a porcentagem da operação concluída. A saída será assim:done: true metadata: ... progress: - endTime: '2022-03-01T00:28:06.691403Z' progressPercent: 100 startTime: '2022-03-01T00:28:04.221401Z' - endTime: '2022-03-01T00:28:17.624588Z' startTime: '2022-03-01T00:28:06.691403Z' progressPercent: 100 ...
REST v1
Consiga o ID da operação:
gcloud spanner operations list --instance=INSTANCE-NAME \ --database=DATABASE-NAME --type=DATABASE_UPDATE_DDL
Substitua:
- INSTANCE-NAME com o nome da instância do Spanner.
- DATABASE-NAME pelo nome do banco de dados.
Verifique o andamento da operação.
Antes de usar os dados da solicitação abaixo, faça as substituições a seguir:
- PROJECT-ID: o ID do projeto.
- INSTANCE-ID: o ID da instância
- DATABASE-ID: o ID do banco de dados.
- OPERATION-ID: o ID da operação.
Método HTTP e URL:
GET https://spanner.googleapis.com/v1/projects/PROJECT-ID/instances/INSTANCE-ID/databases/DATABASE-ID/operations/OPERATION-ID
Para enviar a solicitação, expanda uma destas opções:
Você receberá uma resposta JSON semelhante a esta:
{ ... "progress": [ { "progressPercent": 100, "startTime": "2023-05-27T00:52:27.366688Z", "endTime": "2023-05-27T00:52:30.184845Z" }, { "progressPercent": 100, "startTime": "2023-05-27T00:52:30.184845Z", "endTime": "2023-05-27T00:52:40.750959Z" } ], ... "done": true, "response": { "@type": "type.googleapis.com/google.protobuf.Empty" } }
Se a operação demorar muito, você poderá cancelá-la. Para mais informações, consulte Cancelar uma operação de banco de dados de longa duração.
Excluir um banco de dados
A exclusão de um banco de dados remove permanentemente o banco de dados e todos os respectivos dados. Não é possível desfazer a exclusão do banco de dados. Se a proteção contra exclusão de banco de dados estiver ativada em um banco de dados, não será possível excluí-lo até que você desative a proteção contra exclusão.
Os backups atuais não são excluídos quando um banco de dados é excluído. Para mais informações, consulte Backup e restauração.
Console do Google Cloud
No console Google Cloud , acesse a página Instâncias do Spanner.
Selecione a instância que contém o banco de dados a ser excluído.
Selecione o banco de dados.
Clique em Excluir banco de dados. Uma confirmação aparece.
Digite o nome do banco de dados e clique em Excluir.
gcloud
Para excluir um banco de dados com a ferramenta de linha de comando gcloud
, use
gcloud spanner databases delete
.
gcloud spanner databases delete \ (DATABASE : --instance=INSTANCE)
As seguintes opções são obrigatórias:
DATABASE
- ID do banco de dados ou identificador totalmente qualificado do banco de dados. Se o identificador totalmente qualificado for fornecido, a flag
--instance
deverá ser omitida. --instance=INSTANCE
- A instância do Spanner para o banco de dados.
Para mais detalhes, consulte a
referência gcloud
.
DDL
A DDL não é compatível com a sintaxe de exclusão de banco de dados.
A seguir
- Crie um banco de dados e carregue dados de amostra nele.
- Saiba mais sobre a referência de DDL do GoogleSQL.
- Saiba mais sobre a referência de DDL do PostgreSQL.
- Saiba como fazer backup e restaurar um banco de dados.
- Saiba como evitar a exclusão acidental de bancos de dados.
- Saiba como fazer atualizações no esquema.