Poznámka:
Přístup k této stránce vyžaduje autorizaci. Můžete se zkusit přihlásit nebo změnit adresáře.
Přístup k této stránce vyžaduje autorizaci. Můžete zkusit změnit adresáře.
V tomto rychlém startu nasadíte základní aplikaci Azure Cosmos DB for NoSQL pomocí sady Azure SDK pro .NET. Azure Cosmos DB for NoSQL je úložiště dat bez schématu, které umožňuje aplikacím ukládat nestrukturovaná data v cloudu. Dotazování dat v kontejnerech a provádění běžných operací s jednotlivými položkami pomocí sady Azure SDK pro .NET
Referenční dokumentace k rozhraní API | Zdrojový kód knihovny | Balíček (NuGet) | Azure Developer CLI
Požadavky
- Azure Developer CLI
- Docker Desktop
- .NET 9.0
Pokud nemáte účet Azure, vytvořte si bezplatný účet před tím, než začnete.
Inicializace projektu
Pomocí Azure Developer CLI (azd) vytvořte účet Azure Cosmos DB for NoSQL 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 loginSlouží
azd initk inicializaci projektu.azd init --template cosmos-db-nosql-dotnet-quickstartBě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 upBěhem procesu zřizování vyberte své předplatné, požadované umístění a cílovou skupinu zdrojů. 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 Microsoft.Azure.Cosmos .
Otevřete terminál a přejděte do
/src/websložky.cd ./src/webPokud ještě není nainstalovaný, nainstalujte
Microsoft.Azure.Cosmosbalíček pomocídotnet add package.dotnet add package Microsoft.Azure.Cosmos --version 3.*Pokud ještě není nainstalovaný, nainstalujte
Azure.Identitybalíček.dotnet add package Azure.Identity --version 1.12.*Otevřete a zkontrolujte soubor src/web/Cosmos.Samples.NoSQL.Quickstart.Web.csproj a ověřte, že
Microsoft.Azure.Cosmosexistují oběAzure.Identitypoložky.
Import knihoven
Importujte obory názvů Azure.Identity a Microsoft.Azure.Cosmos do kódu vaší aplikace.
using Azure.Identity;
using Microsoft.Azure.Cosmos;
Objektový model
| Název | Popis |
|---|---|
| CosmosClient | Tato třída je primární klientskou třídou a slouží ke správě metadat nebo databází pro celý účet. |
| Database | Tato třída představuje databázi v rámci účtu. |
| Container | Tato třída se primárně používá k provádění operací čtení, aktualizace a odstraňování v kontejneru nebo v položkách uložených v kontejneru. |
| PartitionKey | Tato třída reprezentuje logický klíč oddílu. Tato třída se vyžaduje pro mnoho běžných operací a dotazů. |
Příklady kódu
- Ověření klienta
- Získání databáze
- Získání kontejneru
- Vytvoření položky
- Získejte položku
- Položky dotazu
Vzorový kód v šabloně používá databázi pojmenovanou cosmicworks a kontejner s názvem products. Kontejner products obsahuje podrobnosti, jako je název, kategorie, množství, jedinečný identifikátor a příznak prodeje pro každý produkt. Kontejner používá vlastnost /category jako logický klíč oddílu.
Ověření klienta
Tato ukázka vytvoří novou instanci CosmosClient třídy a ověří se pomocí DefaultAzureCredential instance.
DefaultAzureCredential credential = new();
CosmosClient client = new(
accountEndpoint: "<azure-cosmos-db-nosql-account-endpoint>",
tokenCredential: new DefaultAzureCredential()
);
Získání databáze
Slouží client.GetDatabase k načtení existující databáze s názvem cosmicworks.
Database database = client.GetDatabase("cosmicworks");
Získání kontejneru
Načtení existujícího products kontejneru pomocí database.GetContainer.
Container container = database.GetContainer("products");
Vytvoření položky
Sestavte typ záznamu jazyka C# se všemi členy, které chcete serializovat do formátu JSON. V tomto příkladu má typ jedinečný identifikátor a pole pro kategorii, název, množství, cenu a prodej.
public record Product(
string id,
string category,
string name,
int quantity,
decimal price,
bool clearance
);
Vytvoření položky v kontejneru pomocí container.UpsertItem. Tato metoda vytvoří nebo upraví položku, čímž účinně nahradí položku, pokud již existuje.
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")
);
Přečíst položku
Proveďte operaci čtení bodu pomocí polí jedinečného identifikátoru (id) i klíče oddílu. Použijte container.ReadItem k efektivnímu načtení konkrétní položky.
ItemResponse<Product> response = await container.ReadItemAsync<Product>(
id: "aaaaaaaa-0000-1111-2222-bbbbbbbbbbbb",
partitionKey: new PartitionKey("gear-surf-surfboards")
);
Položky dotazu
Proveďte dotaz na více položek v kontejneru pomocí container.GetItemQueryIterator. Pomocí tohoto parametrizovaného dotazu vyhledejte všechny položky v zadané kategorii:
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
);
Parsujte stránkované výsledky dotazu tak, že projdete každou stránku výsledků pomocí feed.ReadNextAsync. Použijte feed.HasMoreResults k určení, zda na začátku každé smyčky zbývají nějaké výsledky.
List<Product> items = new();
while (feed.HasMoreResults)
{
FeedResponse<Product> response = await feed.ReadNextAsync();
foreach (Product item in response)
{
items.Add(item);
}
}
Prozkoumání dat
K prozkoumání dat NoSQL použijte rozšíření Visual Studio Code pro Azure Cosmos DB. Můžete provádět základní databázové operace, mezi které patří mimo jiné:
- Provádění dotazů pomocí knihy výstřižků nebo editoru dotazů
- Úpravy, aktualizace, vytváření a odstraňování položek
- Import hromadných dat z jiných zdrojů
- Správa databází a kontejnerů
Další informace viz Použití rozšíření Visual Studio Code pro prozkoumání Azure Cosmos DB pro NoSQL data.
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