Aspire.Hosting.Azure.Sql
9.3.1
Prefix Reserved
dotnet add package Aspire.Hosting.Azure.Sql --version 9.3.1
NuGet\Install-Package Aspire.Hosting.Azure.Sql -Version 9.3.1
<PackageReference Include="Aspire.Hosting.Azure.Sql" Version="9.3.1" />
<PackageVersion Include="Aspire.Hosting.Azure.Sql" Version="9.3.1" />
<PackageReference Include="Aspire.Hosting.Azure.Sql" />
paket add Aspire.Hosting.Azure.Sql --version 9.3.1
#r "nuget: Aspire.Hosting.Azure.Sql, 9.3.1"
#addin nuget:?package=Aspire.Hosting.Azure.Sql&version=9.3.1
#tool nuget:?package=Aspire.Hosting.Azure.Sql&version=9.3.1
Aspire.Hosting.Azure.Sql library
Provides extension methods and resource definitions for a .NET Aspire AppHost to configure Azure SQL DB.
Getting started
Prerequisites
- Azure subscription - create one for free
Install the package
Install the .NET Aspire Azure SQL Server Hosting library with NuGet:
dotnet add package Aspire.Hosting.Azure.Sql
Configure Azure Provisioning for local development
Adding Azure resources to the .NET Aspire application model will automatically enable development-time provisioning for Azure resources so that you don't need to configure them manually. Provisioning requires a number of settings to be available via .NET configuration. Set these values in user secrets in order to allow resources to be configured automatically.
{
"Azure": {
"SubscriptionId": "<your subscription id>",
"ResourceGroupPrefix": "<prefix for the resource group>",
"Location": "<azure location>"
}
}
NOTE: Developers must have Owner access to the target subscription so that role assignments can be configured for the provisioned resources.
Usage example
In the AppHost.cs file of AppHost
, register a SqlServer database and consume the connection using the following methods:
var sql = builder.AddAzureSqlServer("sql")
.AddDatabase("sqldata");
var myService = builder.AddProject<Projects.MyService>()
.WithReference(sql);
The WithReference
method configures a connection in the MyService
project named sqldata
. In the Program.cs file of MyService
, the sql connection can be consumed using the client library Aspire.Microsoft.Data.SqlClient:
builder.AddSqlServerClient("sqldata");
Azure SQL DB defaults
Unless otherwise specified, the Azure SQL DB created will be a 2vCores General Purpose Serverless database (GP_S_Gen5_2) with the free offer enabled.
Read more about the free offer here: Deploy Azure SQL Database for free
The free offer is configured so that when the maximum usage limit is reached, the database is stopped to avoid incurring in unexpected costs.
If you don't want to use the free offer and instead deploy the database use the default sku set by Azure, use the WithAzureDefaultSku
method:
var sql = builder.AddAzureSqlServer("sql")
.AddDatabase("db", "my-db-name")
.WithAzureDefaultSku();
Setting a specific SKU
If you want to manually define what SKU must be used when deploying the Azure SQL DB resource, use the ConfigureInfrastructure
method:
var sqlSrv = builder.AddAzureSqlServer("sqlsrv")
.ConfigureInfrastructure(infra => {
var azureResources = infra.GetProvisionableResources();
var azureDb = azureResources.OfType<SqlDatabase>().Single();
azureDb.Sku = new SqlSku() { Name = "HS_Gen5_2" };
})
.AddDatabase("sqldb", "DatabaseName");
.RunAsContainer();
Additional documentation
- https://learn.microsoft.com/dotnet/framework/data/adonet/sql/
- https://learn.microsoft.com/dotnet/api/system.data.sqlclient.sqlconnection
- https://github.com/dotnet/aspire/tree/main/src/Components/README.md
Feedback & contributing
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
-
net8.0
- Aspire.Hosting.Azure (>= 9.3.1)
- Aspire.Hosting.SqlServer (>= 9.3.1)
- AspNetCore.HealthChecks.SqlServer (>= 9.0.0)
- AspNetCore.HealthChecks.Uris (>= 9.0.0)
- Azure.Core (>= 1.46.0)
- Azure.Identity (>= 1.13.2)
- Azure.Provisioning (>= 1.0.0)
- Azure.Provisioning.KeyVault (>= 1.0.0)
- Azure.Provisioning.Sql (>= 1.0.0)
- Azure.ResourceManager.Authorization (>= 1.1.4)
- Azure.ResourceManager.KeyVault (>= 1.3.2)
- Azure.ResourceManager.Resources (>= 1.9.1)
- Azure.Security.KeyVault.Secrets (>= 4.7.0)
- Google.Protobuf (>= 3.30.2)
- Grpc.AspNetCore (>= 2.71.0)
- Grpc.Net.ClientFactory (>= 2.71.0)
- Grpc.Tools (>= 2.72.0)
- Humanizer.Core (>= 2.14.1)
- JsonPatch.Net (>= 3.3.0)
- KubernetesClient (>= 16.0.7)
- Microsoft.Data.SqlClient (>= 6.0.2)
- Microsoft.Extensions.Configuration.Abstractions (>= 8.0.0)
- Microsoft.Extensions.Configuration.Binder (>= 8.0.2)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 8.0.2)
- Microsoft.Extensions.Diagnostics.HealthChecks (>= 8.0.15)
- Microsoft.Extensions.Hosting (>= 8.0.1)
- Microsoft.Extensions.Hosting.Abstractions (>= 8.0.1)
- Microsoft.Extensions.Http (>= 8.0.1)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.3)
- Microsoft.Extensions.Options (>= 8.0.2)
- Microsoft.Extensions.Primitives (>= 8.0.0)
- Newtonsoft.Json (>= 13.0.3)
- Polly.Core (>= 8.5.2)
- StreamJsonRpc (>= 2.21.69)
- System.IO.Hashing (>= 9.0.4)
- System.Text.Json (>= 8.0.5)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories (1)
Showing the top 1 popular GitHub repositories that depend on Aspire.Hosting.Azure.Sql:
Repository | Stars |
---|---|
rstropek/Samples
|
Version | Downloads | Last updated | |
---|---|---|---|
9.3.1 | 592 | 6/10/2025 | |
9.3.0 | 4,718 | 5/19/2025 | |
9.2.1 | 5,833 | 4/24/2025 | |
9.2.0 | 6,466 | 4/10/2025 | |
9.1.0 | 22,213 | 2/25/2025 | |
9.0.0 | 29,129 | 11/12/2024 | |
9.0.0-rc.1.24511.1 | 986 | 10/15/2024 | |
8.2.2 | 5,022 | 10/24/2024 | |
8.2.1 | 5,293 | 9/26/2024 | |
8.2.0 | 12,389 | 8/29/2024 | |
8.1.0 | 3,931 | 7/23/2024 | |
8.0.2 | 2,798 | 6/28/2024 | |
8.0.1 | 3,306 | 5/21/2024 | |
8.0.0 | 390 | 5/21/2024 | |
8.0.0-preview.7.24251.11 | 606 | 5/7/2024 | |
8.0.0-preview.6.24214.1 | 626 | 4/23/2024 | |
8.0.0-preview.5.24201.12 | 835 | 4/9/2024 |