Rychlý start: Azure Cosmos DB pro knihovnu tabulek pro .NET
PLATÍ PRO: Stůl
V tomto rychlém startu se dozvíte, jak začít pracovat se službou Azure Cosmos DB for Table z aplikace .NET. Azure Cosmos DB for Table je úložiště dat bez schématu, které umožňuje aplikacím ukládat strukturovaná data tabulek v cloudu. Naučíte se vytvářet tabulky, řádky a provádět základní úlohy v rámci prostředku služby Azure Cosmos DB pomocí sady Azure SDK pro .NET.
Referenční dokumentace k | rozhraní API – Balíček zdrojového kódu | knihovny (NuGet) | Azure Developer CLI
Požadavky
- Účet Azure s aktivním předplatným. Vytvoření účtu zdarma
- Azure Developer CLI
- Docker Desktop
- .NET 9.0
Inicializace projektu
Pomocí Azure Developer CLI (azd
) vytvořte účet Azure Cosmos DB for Table a nasaďte kontejnerizovanou ukázkovou aplikaci. Ukázková aplikace používá klientskou knihovnu ke správě, vytváření, čtení a dotazování ukázkových dat.
Otevřete terminál v prázdném adresáři.
Pokud ještě nejste ověřeni, ověřte se v Azure Developer CLI pomocí
azd auth login
. Postupujte podle kroků určených nástrojem k ověření v rozhraní příkazového řádku pomocí vašich upřednostňovaných přihlašovacích údajů Azure.azd auth login
Slouží
azd init
k inicializaci projektu.azd init --template cosmos-db-table-dotnet-quickstart
Během inicializace nakonfigurujte jedinečný název prostředí.
Nasaďte účet služby Azure Cosmos DB pomocí
azd up
. Šablony Bicep také nasazují ukázkovou webovou aplikaci.azd up
Během procesu zřizování vyberte své předplatné, požadované umístění a cílovou skupinu prostředků. Počkejte na dokončení procesu zřizování. Proces může trvat přibližně pět minut.
Po dokončení zřizování prostředků Azure se do výstupu zahrne adresa URL spuštěné webové aplikace.
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.
Pomocí adresy URL v konzole přejděte do webové aplikace v prohlížeči. Sledujte výstup spuštěné aplikace.
Instalace klientské knihovny
Klientská knihovna je k dispozici prostřednictvím Balíčku NuGet Azure.Data.Tables
.
Otevřete terminál a přejděte do
/src/web
složky.cd ./src/web
Pokud ještě není nainstalovaný, nainstalujte
Azure.Data.Tables
balíček pomocídotnet add package
.dotnet add package Azure.Data.Tables
Otevřete a zkontrolujte soubor src/web/Microsoft.Samples.Cosmos.Table.Quickstart.Web.csproj a ověřte, že
Azure.Data.Tables
položka existuje.
Objektový model
Název | Popis |
---|---|
TableServiceClient | Tato třída je primární klientskou třídou a slouží ke správě metadat nebo databází pro celý účet. |
TableClient | Tato třída představuje klienta pro tabulku v rámci účtu. |
Příklady kódu
Vzorový kód v šabloně používá tabulku s názvem cosmicworks-products
. Tabulka cosmicworks-products
obsahuje podrobnosti, jako je název, kategorie, množství, cena, jedinečný identifikátor a příznak prodeje pro každý produkt. Kontejner používá jedinečný identifikátor* jako klíč řádku a kategorii jako klíč oddílu.
Ověření klienta
Tato ukázka vytvoří novou instanci TableServiceClient
třídy.
TableServiceClient serviceClient = new(
endpoint: new Uri("<azure-cosmos-db-table-account-endpoint>"),
credential
);
Získání tabulky
Tato ukázka vytvoří instanci TableClient
třídy pomocí GetTableClient
metody TableServiceClient
třídy.
TableClient client = serviceClient.GetTableClient(
tableName: "<azure-cosmos-db-table-name>"
);
Vytvoření položky
Nejjednodušší způsob, jak vytvořit novou položku v tabulce, je vytvořit třídu, která implementuje ITableEntity
rozhraní. Potom můžete do třídy přidat vlastní vlastnosti, které naplní sloupce dat v daném řádku tabulky.
public record Product : ITableEntity
{
public string RowKey { get; set; } = $"{Guid.NewGuid()}";
public string PartitionKey { get; set; } = String.Empty;
public string Name { get; set; } = String.Empty;
public int Quantity { get; set; } = 0;
public decimal Price { get; set; } = 0.0m;
public bool Clearance { get; set; } = false;
public ETag ETag { get; set; } = ETag.All;
public DateTimeOffset? Timestamp { get; set; }
};
Vytvořte položku v kolekci pomocí Product
třídy voláním TableClient.AddEntityAsync<T>
.
Product entity = new()
{
RowKey = "68719518391",
PartitionKey = "gear-surf-surfboards",
Name = "Surfboard",
Quantity = 10,
Price = 300.00m,
Clearance = true
};
Response response = await client.UpsertEntityAsync<Product>(
entity: entity,
mode: TableUpdateMode.Replace
);
Získání položky
Pomocí metody můžete načíst konkrétní položku z tabulky TableClient.GetEntityAsync<T>
. partitionKey
Zadejte parametry a rowKey
jako k identifikaci správného řádku pro rychlé čtení této položky.
Response<Product> response = await client.GetEntityAsync<Product>(
rowKey: "68719518391",
partitionKey: "gear-surf-surfboards"
);
Dotazování položek
Po vložení položky můžete také spustit dotaz, který pomocí metody získá všechny položky, které odpovídají určitému TableClient.Query<T>
filtru. Tento příklad filtruje produkty podle kategorie pomocí syntaxe Linq , což je výhoda použití typových ITableEntity
modelů, jako je Product
třída.
Poznámka:
Položky můžete dotazovat také pomocí syntaxe OData . Příklad tohoto přístupu si můžete prohlédnout v kurzu Dotazování na data .
string category = "gear-surf-surfboards";
AsyncPageable<Product> results = client.QueryAsync<Product>(
product => product.PartitionKey == category
);
Parsujte stránkované výsledky dotazu tak, že projdete každou stránku výsledků pomocí asynchronní smyčky.
List<Product> entities = new();
await foreach (Product product in results)
{
entities.Add(product);
}
Vyčištění prostředků
Pokud už ukázkovou aplikaci nebo prostředky nepotřebujete, odeberte odpovídající nasazení a všechny prostředky.
azd down