Observação
O acesso a essa página exige autorização. Você pode tentar entrar ou alterar diretórios.
O acesso a essa página exige autorização. Você pode tentar alterar os diretórios.
Neste início rápido, você implantará um aplicativo básico do Azure Cosmos DB for Table usando o SDK do Azure para Java. O Azure Cosmos DB for Table é um armazenamento de dados sem esquema que permite que aplicativos armazenem dados de tabela estruturados na nuvem. Você aprenderá a criar tabelas, linhas e executar tarefas básicas no recurso do Azure Cosmos DB usando o SDK do Azure para Java.
Documentação de referência da API | Código-fonte da biblioteca | Pacote (Maven) | Azure Developer CLI
Pré-requisitos
- Azure Developer CLI
- Área de Trabalho do Docker
- Java 21
Se você ainda não tiver uma conta do Azure, crie uma conta gratuita antes de começar.
Inicializar o projeto
Use a Azure Developer CLI (azd) para criar uma conta do Azure Cosmos DB for Table e implantar um aplicativo de exemplo em contêineres. O aplicativo de exemplo usa a biblioteca de clientes para gerenciar, criar, ler e consultar dados de exemplo.
Abra um terminal em um diretório vazio.
Se você ainda não estiver autenticado, autentique-se na Azure Developer CLI usando
azd auth login. Siga as etapas especificadas pela ferramenta para se autenticar na CLI usando suas credenciais preferenciais do Azure.azd auth loginExecute
azd initpara inicializar o projeto.azd init --template cosmos-db-table-java-quickstartDurante a inicialização, configure um nome de ambiente exclusivo.
Implante a conta do Azure Cosmos DB usando
azd up. Os modelos do Bicep também implantam um aplicativo Web de exemplo.azd upDurante o processo de provisionamento, selecione a sua assinatura, o local desejado e o grupo de recursos de destino. Aguarde o processo de provisionamento ser concluído. O processo pode levar aproximadamente cinco minutos.
Depois que o provisionamento dos recursos do Azure for concluído, uma URL para o aplicativo Web em execução será incluída na saída.
Deploying services (azd deploy) (✓) Done: Deploying service web - Endpoint: <https://[container-app-sub-domain].azurecontainerapps.io> SUCCESS: Your application was provisioned and deployed to Azure in 5 minutes 0 seconds.Use a URL no console para navegar até seu aplicativo Web no navegador. Observe a saída do aplicativo em execução.
Instalar a biblioteca de clientes
A biblioteca de clientes está disponível por meio do Maven, como o pacote azure-data-tables.
Navegue até a pasta
/src/webe abra o arquivo pom.xml.cd ./srcCaso ela ainda não exista, adicione uma entrada ao pacote
azure-data-tables.<dependency> <groupId>com.azure</groupId> <artifactId>azure-data-tables</artifactId> </dependency>
Importar bibliotecas
Importe todos os namespaces necessários para o código do aplicativo.
import com.azure.core.http.rest.PagedFlux;
import com.azure.data.tables.TableAsyncClient;
import com.azure.data.tables.TableClientBuilder;
import com.azure.data.tables.models.ListEntitiesOptions;
import com.azure.data.tables.models.TableEntity;
import com.azure.identity.DefaultAzureCredential;
import com.azure.identity.DefaultAzureCredentialBuilder;
Modelo de objeto
| Nome | Descrição |
|---|---|
TableServiceAsyncClient |
Este tipo é o tipo de cliente principal e é usado para gerenciar metadados ou bancos de dados em toda a conta. |
TableAsyncClient |
Este tipo representa o cliente para uma tabela dentro da conta. |
Exemplos de código
O código de exemplo no modelo usa uma tabela chamada cosmicworks-products. A tabela cosmicworks-products contém detalhes como nome, categoria, quantidade, preço, um identificador exclusivo e um sinalizador de venda para cada produto. O contêiner usa um identificador exclusivo* como a chave de linha e a categoria como uma chave de partição.
Autenticar o cliente
Este exemplo cria uma nova instância da classe TableServiceAsyncClient.
DefaultAzureCredential azureTokenCredential = new DefaultAzureCredentialBuilder()
.build();
TableServiceAsyncClient client = new TableServiceClientBuilder()
.endpoint("<azure-cosmos-db-table-account-endpoint>")
.credential(credential)
.buildAsyncClient();
Obter uma tabela
Este exemplo cria uma instância da classe TableAsyncClient usando o método GetTableClient da classe TableServiceClient.
TableAsyncClient table = client
.getTableClient("<azure-cosmos-db-table-name>");
Criar uma entidade
A maneira mais fácil de criar uma nova entidade em uma tabela é usando createEntity.
String rowKey = "aaaaaaaa-0000-1111-2222-bbbbbbbbbbbb";
String partitionKey = "gear-surf-surfboards";
TableEntity entity = new TableEntity(partitionKey, rowKey)
.addProperty("Name", "Yamba Surfboard")
.addProperty("Quantity", 12)
.addProperty("Price", 850.00)
.addProperty("Sale", false);
Crie uma entidade na coleção usando upsertEntity.
Mono<Void> response = table.upsertEntity(entity);
Obter uma entidade
Você pode recuperar uma entidade específica de uma tabela usando getEntity.
String rowKey = "aaaaaaaa-0000-1111-2222-bbbbbbbbbbbb";
String partitionKey = "gear-surf-surfboards";
TableEntity entity = table.getEntity(partitionKey, rowKey);
Consultar entidades
Depois de inserir uma entidade, você também pode executar uma consulta para obter todas as entidades que correspondem a um filtro específico usando listEntities e a classe ListEntitiesOptions. Use o método setFilter para especificar um filtro OData de cadeia de caracteres.
ListEntitiesOptions options = new ListEntitiesOptions()
.setFilter("PartitionKey eq 'gear-surf-surfboards'");
PagedFlux<TableEntity> tableEntities = table.listEntities(options, null, null);
Analise os resultados paginados da consulta usando uma assinatura.
tableEntities
.DoOnNext(entity -> {
// Do something
});
Limpar os recursos
Quando você não precisar mais dos recursos ou do aplicativo de exemplo, remova a implantação correspondente e todos os recursos.
azd down