using ByteTerrace.Ouroboros.Database.SqlClient;
using Microsoft.Data.SqlClient;
var options = MsSqlClientOptions.New(
connectionString: "Server=(localdb)\\MSSQLLocalDb;Initial Catalog=master;",
providerFactory: SqlClientFactory.Instance
);
var client = MsSqlClient.New(options: options);
_ = client
.ToIDbClient()
.ExecuteStoredProcedure(
name: "sp_tables",
schemaName: "dbo"
);
appsettings.json (or equivalent)
{
"ConnectionStrings": {
"LocalDb": {
"type": "Microsoft.Data.SqlClient.SqlClientFactory, Microsoft.Data.SqlClient, Version=4.1.0.0, Culture=neutral, PublicKeyToken=23ec7fc2d6eaa4a5",
"value": "Server=(localdb)\\MSSQLLocalDb;Initial Catalog=master;"
}
},
"Logging": {
"LogLevel": {
"ByteTerrace.Ouroboros.Database": "None" // Set to Trace for debugging output.
}
}
}
Program.cs
using ByteTerrace.Ouroboros.Database.SqlClient;
var builder = WebApplication.CreateBuilder(args: args);
builder
.Services
.AddMsSqlClients(configuration: builder.Configuration);
ExampleController.cs
using ByteTerrace.Ouroboros.Database;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
namespace MyNamespace
{
[Route("api/[controller]")]
[ApiController]
public class ExampleController : ControllerBase
{
public IDbClientFactory<MsSqlClient> DbClientFactory { get; }
public ExampleController(IDbClientFactory<MsSqlClient> dbClientFactory) {
DbClientFactory = dbClientFactory;
}
[AllowAnonymous]
[HttpGet]
[Route("test-db-connection")]
public async ValueTask<IActionResult> TestDbConnection(CancellationToken cancellationToken) {
using var client = DbClientFactory.NewClient(name: "MyConnection");
await client.OpenConnectionAsync(cancellationToken: cancellationToken);
return Ok();
}
}
}
NuGet References