Dapper.DDD.Repository.DependencyInjection
1.9.1
dotnet add package Dapper.DDD.Repository.DependencyInjection --version 1.9.1
NuGet\Install-Package Dapper.DDD.Repository.DependencyInjection -Version 1.9.1
<PackageReference Include="Dapper.DDD.Repository.DependencyInjection" Version="1.9.1" />
paket add Dapper.DDD.Repository.DependencyInjection --version 1.9.1
#r "nuget: Dapper.DDD.Repository.DependencyInjection, 1.9.1"
// Install Dapper.DDD.Repository.DependencyInjection as a Cake Addin #addin nuget:?package=Dapper.DDD.Repository.DependencyInjection&version=1.9.1 // Install Dapper.DDD.Repository.DependencyInjection as a Cake Tool #tool nuget:?package=Dapper.DDD.Repository.DependencyInjection&version=1.9.1
Dapper.DDD.Repository.DependencyInjection
This package provides support for using Dapper.DDD.Repository with the built-in Dependency Injection in .NET.
Usage
After adding this package, you can use the methods
- ConfigureDapperRepositoryDefaults
- AddTableRepository (Multiple overloads available)
- AddViewRepository (Multiple overloads available)
On an IServiceCollection
to inject all the repositories you're going to use.
Typically this will be available in Program.cs
, though I suggest moving the actual Dapper configuration to your
infrastructure layer, similar to this:
public static IServiceCollection AddInfrastructure(this IServiceCollection services, string connectionString)
{
return services.ConfigureDapperRepositoryDefaults(config =>
{
config.QueryGeneratorFactory = new SqlQueryGeneratorFactory();
config.ConnectionFactory = new SqlConnectionFactory(connectionString);
config.DapperInjectionFactory = new DapperInjectionFactory();
config.Schema = "dbo";
})
.AddTableRepository<WeatherForecast, long>(config =>
{
config.HasKey(weatherForecast => weatherForecast.Id);
config.HasIdentity(weatherForecast => weatherForecast.Id);
config.TableName = "WeatherForecasts";
config.HasDefault(weatherForecast => weatherForecast.Timestamp);
})
.AddTableRepository<WeatherStation, int, IWeatherStationRepository, WeatherStationRepository>(config =>
{
config.HasKey(weatherStation => weatherStation.Id);
config.HasIdentity(weatherStation => weatherStation.Id);
config.TableName = "WeatherStations";
})
.AddViewRepository<WeatherForecastView, IWeatherForecastViewRepository, WeatherForecastViewRepository>(config =>
{
config.ViewName = "WeatherForecastView";
});
}
And then simply calling builder.Services.AddInfrastructure
from Program.cs
.
Documentation
Auto generated documentation via DocFx is available here: https://steffenskov.github.io/Dapper.DDD.Repository/
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. |
-
net8.0
- Dapper.DDD.Repository (>= 1.9.1)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.