Dapper.DDD.Repository.DependencyInjection
1.9.0
dotnet add package Dapper.DDD.Repository.DependencyInjection --version 1.9.0
NuGet\Install-Package Dapper.DDD.Repository.DependencyInjection -Version 1.9.0
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Dapper.DDD.Repository.DependencyInjection" Version="1.9.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Dapper.DDD.Repository.DependencyInjection --version 1.9.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Dapper.DDD.Repository.DependencyInjection, 1.9.0"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Dapper.DDD.Repository.DependencyInjection as a Cake Addin #addin nuget:?package=Dapper.DDD.Repository.DependencyInjection&version=1.9.0 // Install Dapper.DDD.Repository.DependencyInjection as a Cake Tool #tool nuget:?package=Dapper.DDD.Repository.DependencyInjection&version=1.9.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
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
.
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. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net8.0
- Dapper.DDD.Repository (>= 1.9.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.