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 Node.js. 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 Node.js.
Referenční dokumentace k rozhraní API | Zdrojový kód knihovny | Balíček (npm) | Azure Developer CLI
Požadavky
- Azure Developer CLI
- Docker Desktop
- Node.js 22 nebo novější
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 login
Slouží
azd init
k inicializaci projektu.azd init --template cosmos-db-nosql-nodejs-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 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 Správce balíčků Node jako @azure/cosmos
balíček.
Otevřete terminál a přejděte do
/src
složky.cd ./src
Pokud ještě není nainstalovaný, nainstalujte
@azure/cosmos
balíček pomocínpm install
.npm install --save @azure/cosmos
Pokud ještě není nainstalovaný, nainstalujte
@azure/identity
balíček.npm install --save @azure/identity
Otevřete a zkontrolujte soubor src/package.json a ověřte, že
azure-cosmos
azure-identity
obě položky existují.
Import knihoven
Importujte typy DefaultAzureCredential
a CosmosClient
do kódu aplikace.
import { DefaultAzureCredential } from '@azure/identity';
import { CosmosClient } from '@azure/cosmos';
Importujte do kódu aplikace všechny požadované typy.
import { PagedAsyncIterableIterator } from '@azure/core-paging';
import { DefaultAzureCredential, TokenCredential } from '@azure/identity';
import { Container, CosmosClient, Database, FeedResponse, ItemResponse, SqlQuerySpec } from '@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 představuje klíč logické partition. Tato třída se vyžaduje pro mnoho běžných operací a dotazů. |
SqlQuerySpec |
Toto rozhraní představuje dotaz SQL a všechny parametry dotazu. |
Příklady kódu
- Ověření klienta
- Získání databáze
- Získání kontejneru
- Vytvoření položky
- Získejte položku
- Dotazování položek
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á /category
vlastnost jako logický klíč oddílu.
Ověření klienta
Tato ukázka vytvoří novou instanci CosmosClient
typu a ověří se pomocí DefaultAzureCredential
instance.
const credential = new DefaultAzureCredential();
const client = new CosmosClient({
'<azure-cosmos-db-nosql-account-endpoint>',
aadCredentials: credential
});
const credential: TokenCredential = new DefaultAzureCredential();
const client = new CosmosClient({
'<azure-cosmos-db-nosql-account-endpoint>',
aadCredentials: credential
});
Získání databáze
Slouží client.database
k načtení existující databáze s názvem cosmicworks
.
const database = client.database('cosmicworks');
const database: Database = client.database('cosmicworks');
Získání kontejneru
Načtení existujícího products
kontejneru pomocí database.container
.
const container = database.container('products');
const container: Container = database.container('products');
Vytvoření položky
Sestavte nový objekt 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. Vytvoření položky v kontejneru pomocí container.items.upsert
. Tato metoda položku buď vloží, nebo aktualizuje, a tím účinně nahradí položku, pokud již existuje.
const item = {
'id': 'aaaaaaaa-0000-1111-2222-bbbbbbbbbbbb',
'category': 'gear-surf-surfboards',
'name': 'Yamba Surfboard',
'quantity': 12,
'price': 850.00,
'clearance': false
};
let response = await container.items.upsert(item);
const item: Product = {
'id': 'aaaaaaaa-0000-1111-2222-bbbbbbbbbbbb',
'category': 'gear-surf-surfboards',
'name': 'Yamba Surfboard',
'quantity': 12,
'price': 850.00,
'clearance': false
};
let response: ItemResponse<Product> = await container.items.upsert<Product>(item);
Přečtěte položku
Proveďte operaci bodového čtení pomocí polí jedinečného identifikátoru (id
) a klíče oddílu. Použijte container.item
k získání ukazatele položky a item.read
k efektivnímu načtení konkrétní položky.
const id = 'aaaaaaaa-0000-1111-2222-bbbbbbbbbbbb';
const partitionKey = 'gear-surf-surfboards';
let response = await container.item(id, partitionKey).read();
let read_item = response.resource;
const id = 'aaaaaaaa-0000-1111-2222-bbbbbbbbbbbb';
const partitionKey = 'gear-surf-surfboards';
let response: ItemResponse<Product> = await container.item(id, partitionKey).read<Product>();
let read_item: Product = response.resource!;
Položky k dotazu
Proveďte dotaz na více položek v kontejneru pomocí container.items.query
. Pomocí tohoto parametrizovaného dotazu vyhledejte všechny položky v zadané kategorii:
SELECT * FROM products p WHERE p.category = @category
Načtěte všechny výsledky dotazu pomocí query.fetchAll
. Projděte výsledky dotazu.
const querySpec = {
query: 'SELECT * FROM products p WHERE p.category = @category',
parameters: [
{
name: '@category',
value: 'gear-surf-surfboards'
}
]
};
let response = await container.items.query(querySpec).fetchAll();
for (let item of response.resources) {
// Do something
}
const querySpec: SqlQuerySpec = {
query: 'SELECT * FROM products p WHERE p.category = @category',
parameters: [
{
name: '@category',
value: 'gear-surf-surfboards'
}
]
};
let response: FeedResponse<Product> = await container.items.query<Product>(querySpec).fetchAll();
for (let item of response.resources) {
// Do something
}
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í náčrtníku 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 najdete v tématu Jak používat rozšíření Visual Studio Code k prozkoumání databáze Azure Cosmos DB pro data NoSQL.
Uvolně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