Início Rápido: Como usar o Azure Cosmos DB for NoSQL com o SDK do Azure para linguagem .NET
Neste início rápido, você implantará um aplicativo básico do Azure Cosmos DB for Table usando o SDK do Azure para .NET. 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 dentro do seu recurso do Azure Cosmos DB usando o Azure SDK para .NET.
Documentação de referência da API | Código-fonte da biblioteca | Pacote (NuGet) | Azure Developer CLI
Pré-requisitos
- CLI do Desenvolvedor do Azure
- Docker Desktop
- .NET 9.0
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 login
Execute
azd init
para inicializar o projeto.azd init --template cosmos-db-nosql-dotnet-quickstart
Durante 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 up
Durante 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 NuGet, como o pacote Microsoft.Azure.Cosmos
.
Abra um terminal e vá até a pasta
/src/web
.cd ./src/web
Se o pacote
Microsoft.Azure.Cosmos
ainda não estiver instalado, instale-o usandodotnet add package
.dotnet add package Microsoft.Azure.Cosmos --version 3.*
Instale também o pacote
Azure.Identity
, caso ainda não esteja instalado.dotnet add package Azure.Identity --version 1.12.*
Abra e analise o arquivo src/web/Cosmos.Samples.NoSQL.Quickstart.Web.csproj para validar se as entradas
Microsoft.Azure.Cosmos
eAzure.Identity
existem.
Modelo de objeto
Nome | Descrição |
---|---|
CosmosClient | Essa é a classe de cliente principal e é usada para gerenciar metadados ou bancos de dados em toda a conta. |
Database | Ela representa um banco de dados dentro da conta. |
Container | A classe é usada principalmente para realizar operações de leitura, atualização e exclusão no contêiner ou nos itens armazenados no contêiner. |
PartitionKey | Ela representa uma chave de partição lógica. É necessária também para muitas operações e consultas comuns. |
Exemplos de código
- Autenticar o cliente
- Obter um banco de dados
- Obter um contêiner
- Criar um item
- Obter um item
- Itens de consulta
O código de exemplo do modelo usa um banco de dados chamado cosmicworks
e um contêiner chamado products
. O contêiner products
traz detalhes como o nome, a categoria, a quantidade, um identificador exclusivo e um sinalizador de venda para cada produto. O contêiner usa a propriedade /category
como uma chave de partição lógica.
Autenticar o cliente
Esta amostra cria uma instância da classe CosmosClient
e faz a autenticação usando uma instância de DefaultAzureCredential
.
DefaultAzureCredential credential = new();
CosmosClient client = new(
accountEndpoint: "<azure-cosmos-db-nosql-account-endpoint>",
tokenCredential: new DefaultAzureCredential()
);
Obter um banco de dados
Use client.GetDatabase
para recuperar o banco de dados existente chamado cosmicworks
.
Database database = client.GetDatabase("cosmicworks");
Obter um contêiner
Recupere o contêiner existente products
usando database.GetContainer
.
Container container = database.GetContainer("products");
Criar um item
Crie um tipo de registro C# com todos os membros que você deseja serializar em JSON. Neste exemplo, o tipo tem um identificador exclusivo, além de campos para categoria, nome, quantidade, preço e venda.
public record Product(
string id,
string category,
string name,
int quantity,
decimal price,
bool clearance
);
Crie um item no contêiner usando container.UpsertItem
. Esse método executa upsert no item, substituindo o item efetivamente caso ele já exista.
Product item = new(
id: "aaaaaaaa-0000-1111-2222-bbbbbbbbbbbb",
category: "gear-surf-surfboards",
name: "Yamba Surfboard",
quantity: 12,
price: 850.00m,
clearance: false
);
ItemResponse<Product> response = await container.UpsertItemAsync<Product>(
item: item,
partitionKey: new PartitionKey("gear-surf-surfboards")
);
Ler um item
Realize uma operação de leitura de ponto usando o identificador exclusivo (id
) e os campos de chave de partição. Use container.ReadItem
para recuperar com eficiência o item específico.
ItemResponse<Product> response = await container.ReadItemAsync<Product>(
id: "aaaaaaaa-0000-1111-2222-bbbbbbbbbbbb",
partitionKey: new PartitionKey("gear-surf-surfboards")
);
Itens de consulta
Realize uma consulta em vários itens de um contêiner usando container.GetItemQueryIterator
. Localize todos os itens de uma categoria especificada usando esta consulta parametrizada:
SELECT * FROM products p WHERE p.category = @category
string query = "SELECT * FROM products p WHERE p.category = @category"
var query = new QueryDefinition(query)
.WithParameter("@category", "gear-surf-surfboards");
using FeedIterator<Product> feed = container.GetItemQueryIterator<Product>(
queryDefinition: query
);
Analise os resultados paginados da consulta executando um loop em cada página de resultados com feed.ReadNextAsync
. Use feed.HasMoreResults
para determinar se ainda há resultados no início de cada loop.
List<Product> items = new();
while (feed.HasMoreResults)
{
FeedResponse<Product> response = await feed.ReadNextAsync();
foreach (Product item in response)
{
items.Add(item);
}
}
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