Get started with Azure Cosmos DB for Table using .NET
APPLIES TO: Table
This article shows you how to connect to Azure Cosmos DB for Table using the .NET SDK. Once connected, you can perform operations on tables and items.
Package (NuGet) | Samples | API reference | Library source code | Give Feedback |
- An Azure account with an active subscription. Create an account for free.
- Azure Cosmos DB for Table account. Create a API for Table account.
- .NET 6.0 or later
- Azure Command-Line Interface (CLI) or Azure PowerShell
Create a new .NET application by using the dotnet new
command with the console template.
dotnet new console
Import the Azure.Data.Tables NuGet package using the dotnet add package
command.
dotnet add package Azure.Data.Tables
Build the project with the dotnet build
command.
dotnet build
To connect to the API for Table of Azure Cosmos DB, create an instance of the TableServiceClient
class. This class is the starting point to perform all operations against tables.
To connect to your API for NoSQL account using Microsoft Entra, use a security principal. The exact type of principal will depend on where you host your application code. The table below serves as a quick reference guide.
Where the application runs | Security principal |
---|---|
Local machine (developing and testing) | User identity or service principal |
Azure | Managed identity |
Servers or clients outside of Azure | Service principal |
The Azure.Identity NuGet package contains core authentication functionality that is shared among all Azure SDK libraries.
Import the Azure.Identity NuGet package using the dotnet add package
command.
dotnet add package Azure.Identity
Rebuild the project with the dotnet build
command.
dotnet build
In your code editor, add using directives for Azure.Core
and Azure.Identity
namespaces.
using Azure.Core;
using Azure.Identity;
If you're testing on a local machine, or your application will run on Azure services with direct support for managed identities, obtain an OAuth token by creating a DefaultAzureCredential
instance.
For this example, we saved the instance in a variable of type TokenCredential
as that's a more generic type that's reusable across SDKs.
// Credential class for testing on a local machine or Azure services
TokenCredential credential = new DefaultAzureCredential();
Create a new instance of the CosmosClient class with the COSMOS_ENDPOINT
environment variable and the TokenCredential object as parameters.
// New instance of TableServiceClient class using Microsoft Entra
TableServiceClient client = new(
endpoint: Environment.GetEnvironmentVariable("COSMOS_ENDPOINT")!,
tokenCredential: credential
);
As you build your application, your code will primarily interact with four types of resources:
The API for Table account, which is the unique top-level namespace for your Azure Cosmos DB data.
Tables, which contain a set of individual items in your account.
Items, which represent an individual item in your table.
The following diagram shows the relationship between these resources.
Hierarchical diagram showing an Azure Cosmos DB account at the top. The account has two child table nodes. One of the table nodes includes two child items.
Each type of resource is represented by one or more associated .NET classes or interfaces. Here's a list of the most common types:
Class | Description |
---|---|
TableServiceClient |
This client class provides a client-side logical representation for the Azure Cosmos DB service. The client object is used to configure and execute requests against the service. |
TableClient |
This client class is a reference to a table that may, or may not, exist in the service yet. The table is validated server-side when you attempt to access it or perform an operation against it. |
ITableEntity |
This interface is the base interface for any items that are created in the table or queried from the table. This interface includes all required properties for items in the API for Table. |
TableEntity |
This class is a generic implementation of the ITableEntity interface as a dictionary of key-value pairs. |
The following guides show you how to use each of these classes to build your application.
Guide | Description |
---|---|
Create a table | Create tables |
Create an item | Create items |
Read an item | Read items |
Now that you've connected to an API for Table account, use the next guide to create and manage tables.