Encamina.Enmarcha.Data.EntityFramework 8.1.6-preview-01

This is a prerelease version of Encamina.Enmarcha.Data.EntityFramework.
There is a newer version of this package available.
See the version list below for details.
dotnet add package Encamina.Enmarcha.Data.EntityFramework --version 8.1.6-preview-01                
NuGet\Install-Package Encamina.Enmarcha.Data.EntityFramework -Version 8.1.6-preview-01                
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="Encamina.Enmarcha.Data.EntityFramework" Version="8.1.6-preview-01" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Encamina.Enmarcha.Data.EntityFramework --version 8.1.6-preview-01                
#r "nuget: Encamina.Enmarcha.Data.EntityFramework, 8.1.6-preview-01"                
#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 Encamina.Enmarcha.Data.EntityFramework as a Cake Addin
#addin nuget:?package=Encamina.Enmarcha.Data.EntityFramework&version=8.1.6-preview-01&prerelease

// Install Encamina.Enmarcha.Data.EntityFramework as a Cake Tool
#tool nuget:?package=Encamina.Enmarcha.Data.EntityFramework&version=8.1.6-preview-01&prerelease                

Data - Entity Framework

Nuget package

Entity Framework Data project primarily contains Entity Framework implementations based on the abstractions provided by Encamina.Enmarcha.Data.Abstractions, as well as some other utilities related to Entity Framework.

Setup

Nuget package

First, install NuGet. Then, install Encamina.Enmarcha.Data.EntityFramework from the package manager console:

PM> Install-Package Encamina.Enmarcha.Data.EntityFramework

.NET CLI:

First, install .NET CLI. Then, install Encamina.Enmarcha.Data.EntityFramework from the .NET CLI:

dotnet add package Encamina.Enmarcha.Data.EntityFramework

How to use

In the following example, we will demonstrate how to configure and add an Entity Framework implementation of the IFullUnitOfWork interface to the ServiceCollection, based on the FullUnitOfWork, using the following DbContext.

public class Foo
{
    public int Id { get; set; }
    public string Text { get; set; }
}

public class Bar
{
    public int Id { get; set; }
    public string Text { get; set; }
}

public class MyDBContext : DbContext
{
    public DbSet<Foo> Foos { get; set; }
    public DbSet<Bar> Bars { get; set; }

}

The next step is to inherit from FullUnitOfWork and create a custom class that receives an instance of MyDBContext in its constructor.

public class MyFullUnitOfWork: FullUnitOfWork, IFullUnitOfWork
{
    public MyFullUnitOfWork(MyDBContext dbContext) 
        : base(dbContext)
    {
    }
}

In the Program.cs or a similar entry point file in your project, add the following code:

// Entry point
var builder = WebApplication.CreateBuilder(new WebApplicationOptions
{
   // ...
});

// ...

services.AddDbContext<DatabaseContext>(opt =>
{
    opt.UseSqlServer(configuration.GetConnectionString("DefaultConnection")); // Configures your provider
}, ServiceLifetime.Scoped);

// ...

builder.Services.AddScoped<IFullUnitOfWork, MyFullUnitOfWork>();

And now, we can resolve the IFullUnitOfWork interface with construction injection:

public class MyClass
{
    private readonly IFullUnitOfWork uow;

    public MyClass(IFullUnitOfWork uow)
    {
        this.uow = uow;
    }

    public async Task TestAddFooAndBarAndSaveAsync(CancellationToken cts)
    {
        var fooRepository = uow.GetAsyncRepository<Foo>();
        var barRepository = uow.GetAsyncRepository<Bar>();

        await fooRepository.AddAsync(new Foo() { Text = "Foo1" }, cts);
        await fooRepository.AddAsync(new Foo() { Text = "Foo2" }, cts);
        await barRepository.AddAsync(new Bar() { Text = "Bar1" }, cts);

        await uow.SaveAsync(cts);
    }
}

Within the NuGet package, there are more interfaces along with their corresponding base implementations.

Other functionalities

Inside the NuGet package, you will find some extension methods related to Entity Framework.

// ...

var queryableFoo = dbContext.AsQueryable<Foo>(withNoTracking: true, withIdentityResolution: true);

// More methods available in DbContextExtensions...
Product 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
8.2.0 88 10/22/2024
8.2.0-preview-01-m01 103 9/17/2024
8.1.9-preview-03 69 11/19/2024
8.1.9-preview-02 79 10/22/2024
8.1.9-preview-01 67 10/4/2024
8.1.8 94 9/23/2024
8.1.8-preview-07 87 9/12/2024
8.1.8-preview-06 101 9/11/2024
8.1.8-preview-05 101 9/10/2024
8.1.8-preview-04 109 8/16/2024
8.1.8-preview-03 112 8/13/2024
8.1.8-preview-02 102 8/13/2024
8.1.8-preview-01 97 8/12/2024
8.1.7 105 8/7/2024
8.1.7-preview-09 117 7/3/2024
8.1.7-preview-08 99 7/2/2024
8.1.7-preview-07 96 6/10/2024
8.1.7-preview-06 90 6/10/2024
8.1.7-preview-05 104 6/6/2024
8.1.7-preview-04 96 6/6/2024
8.1.7-preview-03 90 5/24/2024
8.1.7-preview-02 104 5/10/2024
8.1.7-preview-01 95 5/8/2024
8.1.6 124 5/7/2024
8.1.6-preview-08 62 5/2/2024
8.1.6-preview-07 94 4/29/2024
8.1.6-preview-06 94 4/26/2024
8.1.6-preview-05 95 4/24/2024
8.1.6-preview-04 81 4/22/2024
8.1.6-preview-03 95 4/22/2024
8.1.6-preview-02 99 4/17/2024
8.1.6-preview-01 101 4/15/2024
8.1.5 133 4/15/2024
8.1.5-preview-15 93 4/10/2024
8.1.5-preview-14 99 3/20/2024
8.1.5-preview-13 87 3/18/2024
8.1.5-preview-12 112 3/13/2024
8.1.5-preview-11 97 3/13/2024
8.1.5-preview-10 93 3/13/2024
8.1.5-preview-09 99 3/12/2024
8.1.5-preview-08 95 3/12/2024
8.1.5-preview-07 100 3/8/2024
8.1.5-preview-06 75 3/8/2024
8.1.5-preview-05 90 3/7/2024
8.1.5-preview-04 99 3/7/2024
8.1.5-preview-03 93 3/7/2024
8.1.5-preview-02 109 2/28/2024
8.1.5-preview-01 88 2/19/2024
8.1.4 122 2/15/2024
8.1.3 120 2/13/2024
8.1.3-preview-07 86 2/13/2024
8.1.3-preview-06 97 2/12/2024
8.1.3-preview-05 114 2/9/2024
8.1.3-preview-04 106 2/8/2024
8.1.3-preview-03 96 2/7/2024
8.1.3-preview-02 94 2/2/2024
8.1.3-preview-01 90 2/2/2024
8.1.2 122 2/1/2024
8.1.2-preview-9 102 1/22/2024
8.1.2-preview-8 93 1/19/2024
8.1.2-preview-7 93 1/19/2024
8.1.2-preview-6 85 1/19/2024
8.1.2-preview-5 92 1/19/2024
8.1.2-preview-4 92 1/19/2024
8.1.2-preview-3 90 1/18/2024
8.1.2-preview-2 94 1/18/2024
8.1.2-preview-16 86 1/31/2024
8.1.2-preview-15 89 1/31/2024
8.1.2-preview-14 88 1/25/2024
8.1.2-preview-13 89 1/25/2024
8.1.2-preview-12 101 1/23/2024
8.1.2-preview-11 89 1/23/2024
8.1.2-preview-10 88 1/22/2024
8.1.2-preview-1 87 1/18/2024
8.1.1 131 1/18/2024
8.1.0 108 1/18/2024
8.0.3 168 12/29/2023
8.0.1 134 12/14/2023
8.0.0 143 12/7/2023
6.0.4.3 129 12/29/2023
6.0.4.2 122 12/20/2023
6.0.4.1 125 12/19/2023
6.0.4 147 12/4/2023
6.0.3.20 138 11/27/2023
6.0.3.19 149 11/22/2023