RCommon.EFCore
2.4.1
See the version list below for details.
dotnet add package RCommon.EFCore --version 2.4.1
NuGet\Install-Package RCommon.EFCore -Version 2.4.1
<PackageReference Include="RCommon.EFCore" Version="2.4.1" />
<PackageVersion Include="RCommon.EFCore" Version="2.4.1" />
<PackageReference Include="RCommon.EFCore" />
paket add RCommon.EFCore --version 2.4.1
#r "nuget: RCommon.EFCore, 2.4.1"
#:package RCommon.EFCore@2.4.1
#addin nuget:?package=RCommon.EFCore&version=2.4.1
#tool nuget:?package=RCommon.EFCore&version=2.4.1
RCommon.EFCore
Entity Framework Core implementation of the RCommon persistence abstractions. Provides a fully-featured repository with LINQ queries, eager loading, change tracking, and automatic domain event integration -- all backed by EF Core's DbContext.
Features
EFCoreRepository<TEntity>implementingIGraphRepository<T>,ILinqRepository<T>,IReadOnlyRepository<T>, andIWriteOnlyRepository<T>- Full
IQueryable<T>support for composable LINQ queries at the domain layer - Eager loading via
Include/ThenIncludemapped to EF Core'sIIncludableQueryable - Configurable change tracking (enable/disable per repository via the
Trackingproperty) - Paginated query results with ordering support
- Bulk delete via
ExecuteDeleteAsyncfor expression-based batch operations - Named data store support for multi-database scenarios through
IDataStoreFactory RCommonDbContextbase class implementingIDataStorefor seamless factory resolution- Fluent DI configuration to register DbContexts as named data stores
- Automatic entity event tracking for domain event dispatching on add, update, and delete
- Soft delete -- entities implementing
ISoftDeleteare automatically filtered on reads and logically deleted on writes - Multitenancy -- entities implementing
IMultiTenantare automatically filtered by tenant on reads and stamped withTenantIdon writes - Targets .NET 8, .NET 9, and .NET 10
Installation
dotnet add package RCommon.EFCore
Usage
// Configure in Program.cs or Startup
builder.Services.AddRCommon()
.WithPersistence<EFCorePerisistenceBuilder>(ef =>
{
ef.AddDbContext<ApplicationDbContext>("ApplicationDb", options =>
options.UseSqlServer(builder.Configuration.GetConnectionString("ApplicationDb")));
ef.SetDefaultDataStore(defaults =>
defaults.DefaultDataStoreName = "ApplicationDb");
});
Your DbContext must inherit from RCommonDbContext:
public class ApplicationDbContext : RCommonDbContext
{
public ApplicationDbContext(DbContextOptions<ApplicationDbContext> options)
: base(options) { }
public DbSet<Order> Orders => Set<Order>();
public DbSet<Customer> Customers => Set<Customer>();
}
Then inject and use the repository abstractions:
public class OrderService
{
private readonly IGraphRepository<Order> _orderRepo;
public OrderService(IGraphRepository<Order> orderRepo)
{
_orderRepo = orderRepo;
}
public async Task<ICollection<Order>> GetCustomerOrdersAsync(int customerId)
{
_orderRepo.Include(o => o.LineItems);
return await _orderRepo.FindAsync(o => o.CustomerId == customerId);
}
}
Soft Delete and Multitenancy
EFCoreRepository<TEntity> automatically supports soft delete and multitenancy when your entities implement the opt-in interfaces:
using RCommon.Entities;
public class Customer : BusinessEntity<int>, ISoftDelete, IMultiTenant
{
public string Name { get; set; }
public bool IsDeleted { get; set; }
public string? TenantId { get; set; }
}
Reads automatically exclude soft-deleted records and scope to the current tenant:
// Both filters applied transparently — only active customers for the current tenant
var customers = await _customerRepo.FindAsync(c => c.Name.StartsWith("A"));
Writes automatically stamp the tenant and support logical deletion:
// TenantId stamped automatically from ITenantIdAccessor
await _customerRepo.AddAsync(new Customer { Name = "Acme" });
// Soft delete — sets IsDeleted = true, performs UPDATE via EF Core
await _customerRepo.DeleteAsync(customer, isSoftDelete: true);
Key Types
| Type | Description |
|---|---|
EFCoreRepository<TEntity> |
Concrete repository backed by EF Core with full CRUD, LINQ, eager loading, and change tracking |
RCommonDbContext |
Abstract DbContext base class implementing IDataStore for named data store resolution |
EFCorePerisistenceBuilder |
Fluent builder for registering EF Core DbContexts and repository services in DI |
IEFCorePersistenceBuilder |
Builder interface exposing AddDbContext<T>() for registering named DbContexts |
Documentation
For full documentation, visit rcommon.com.
Related Packages
- RCommon.Persistence - Core persistence abstractions (required dependency)
- RCommon.Dapper - Dapper implementation
- RCommon.Linq2Db - Linq2Db implementation
License
Licensed under the Apache License, Version 2.0.
| 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 is compatible. 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 is compatible. 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. |
-
net10.0
- Microsoft.EntityFrameworkCore (>= 10.0.2)
- Microsoft.EntityFrameworkCore.Relational (>= 10.0.2)
- RCommon.Core (>= 2.4.1)
- RCommon.Persistence (>= 2.4.1)
-
net8.0
- Microsoft.EntityFrameworkCore (>= 8.0.16)
- Microsoft.EntityFrameworkCore.Relational (>= 8.0.16)
- RCommon.Core (>= 2.4.1)
- RCommon.Persistence (>= 2.4.1)
-
net9.0
- Microsoft.EntityFrameworkCore (>= 9.0.10)
- Microsoft.EntityFrameworkCore.Relational (>= 9.0.10)
- RCommon.Core (>= 2.4.1)
- RCommon.Persistence (>= 2.4.1)
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 |
|---|---|---|
| 2.4.2-alpha.0.10 | 52 | 4/5/2026 |
| 2.4.2-alpha.0.9 | 47 | 3/26/2026 |
| 2.4.2-alpha.0.8 | 47 | 3/26/2026 |
| 2.4.2-alpha.0.7 | 44 | 3/26/2026 |
| 2.4.2-alpha.0.6 | 49 | 3/25/2026 |
| 2.4.2-alpha.0.5 | 48 | 3/24/2026 |
| 2.4.2-alpha.0.1 | 45 | 3/24/2026 |
| 2.4.1 | 106 | 2/18/2026 |
| 2.3.2-alpha.0.3 | 55 | 2/18/2026 |
| 2.3.2-alpha.0.2 | 57 | 2/18/2026 |
| 2.3.2-alpha.0.1 | 67 | 2/9/2026 |
| 2.3.1 | 168 | 2/5/2026 |
| 2.3.0 | 103 | 2/3/2026 |
| 2.2.2-alpha.0.1 | 397 | 12/11/2025 |
| 2.2.1-alpha.0.2 | 136 | 10/24/2025 |
| 2.2.1-alpha.0.1 | 142 | 10/24/2025 |
| 2.1.11-alpha.0.2 | 141 | 10/24/2025 |
| 2.1.11-alpha.0.1 | 117 | 7/18/2025 |
| 2.1.10 | 292 | 7/17/2025 |
| 2.1.9-alpha.0.1 | 156 | 7/17/2025 |