SimpleEfCoreRepository 3.0.0
There is a newer version of this package available.
See the version list below for details.
See the version list below for details.
dotnet add package SimpleEfCoreRepository --version 3.0.0
NuGet\Install-Package SimpleEfCoreRepository -Version 3.0.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="SimpleEfCoreRepository" Version="3.0.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="SimpleEfCoreRepository" Version="3.0.0" />
<PackageReference Include="SimpleEfCoreRepository" />
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add SimpleEfCoreRepository --version 3.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: SimpleEfCoreRepository, 3.0.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.
#addin nuget:?package=SimpleEfCoreRepository&version=3.0.0
#tool nuget:?package=SimpleEfCoreRepository&version=3.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
EF.Core.Repository
Simple repository for Ef.Core with basic CRUD functionality The reason I implemented this is because I found myself re-writing basic CRUD functionality over and over again. Most of the time:
- use
.include(...)
to include eager load associated entities - update (add/delete/update) children properties
Using repository pattern with entity framework enforces a consistent convention and that is what this library is aiming towards.
Basic setup
- Entity should have Id property. Using
[Key]
is optional if Id property does not follow common naming convention.
public class DummyModel
{
public string Name { get; set; }
public List<Nested> Children { get; set; }
}
- Create profile which is used to update an entity given a DTO
public class DummyModelProfile : EntityProfile<DummyModel>
{
public void Update(DummyModel entity, DummyModel dto)
{
entity.Name = dto.Name;
// ModifyList will try to add/delete entities based on Id based on whether they
// appear in dto.Children or not
ModifyList(entity.Children, dto.Children, x => x.Id);
}
// Intercept IQueryable to include related entities
public IQueryable<DummyModel> Include<TQueryable>(TQueryable queryable) where TQueryable : IQueryable<DummyModel>
{
return queryable.Include(x => x.Children);
}
}
- Register dependency via
IServiceCollection
extension
var serviceProvider = services
.AddEfRepository<EntityDbContext>(options => options
.Profile(Assembly.GetExecutingAssembly()));
- Use
IBasicCrud
IEfRepository repo = ... // DI inject IEfRepository
// Get IBasicCrud instance
IBasicCrud<DummyModel> = repo.For<DummyModel>(dbContext);
- Available methods in
IBasicCrud
// Get all entities without any filter
Task<IEnumerable<TSource>> GetAll();
// Get all entities given an array of Ids
Task<IEnumerable<TSource>> GetAll<TId>(param TId[]);
// Get all entities given a filter expression
Task<IEnumerable<TSource>> GetAll(Expression<Func<TSource, bool>>);
// Get single entity by Id
Task<TSource> Get<TId>(TId);
// Get single entity given a filter expression
Task<TSource> Get(Expression<Func<TSource, bool>>);
// Save entity
Task<TSource> Save(TSource);
// Save multiple entities
Task<IEnumerable<TSource>> Save(param TSource[]);
// Update entity by Id
Task<TSource> Update<TId>(TId, TSource);
// Update entity by filter expression
Task<TSource> Update(Expression<Func<TSource, bool>>, TSource);
// Delete entity by Id
Task<TSource> Delete<TId>(TId);
// Delete entity given a filter expression
Task<TSource> Delete(Expression<Func<TSource, bool>>);
// This is useful if you want to defer SaveChanges in session mode
// Changes are not automatically saved back to DbContext in session mode
IBasicCrud<TSource, TId> Delayed();
// This is useful if you want don't want to include all related entities
// or turn entities into a "god" object
IBasicCrud<TSource, TId> Light();
Notes:
- "Id" has a type constraint of
: struct
, which means it accepts all primitive types includingGUID
andString
. - Including all associated entities will lead to "god object" which is anti-pattern. I recommend using this library as L2 cache
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. 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. net10.0 was computed. 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. |
.NET Core | netcoreapp3.1 is compatible. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
.NETCoreApp 3.1
- Microsoft.EntityFrameworkCore (>= 3.1.0)
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 | |
---|---|---|---|
3.1.15 | 186 | 6/16/2025 | |
3.1.14 | 1,002 | 4/4/2025 | |
3.1.13 | 150 | 4/4/2025 | |
3.1.12 | 149 | 4/4/2025 | |
3.1.11 | 161 | 4/3/2025 | |
3.1.10 | 212 | 3/31/2025 | |
3.1.8 | 579 | 3/24/2025 | |
3.1.7 | 462 | 3/24/2025 | |
3.1.6 | 335 | 3/24/2025 | |
3.1.5 | 160 | 3/23/2025 | |
3.1.4 | 86 | 3/22/2025 | |
3.1.3 | 171 | 3/19/2025 | |
3.1.2 | 341 | 3/4/2025 | |
3.1.1 | 171 | 2/25/2025 | |
3.1.0 | 108 | 2/24/2025 | |
3.0.22 | 92 | 2/24/2025 | |
3.0.21 | 368 | 12/22/2024 | |
3.0.20 | 178 | 12/10/2024 | |
3.0.19 | 229 | 11/15/2024 | |
3.0.18 | 148 | 11/9/2024 | |
3.0.17 | 113 | 11/9/2024 | |
3.0.16 | 112 | 11/9/2024 | |
3.0.15 | 153 | 11/5/2024 | |
3.0.14 | 465 | 4/28/2023 | |
3.0.13 | 270 | 4/16/2023 | |
3.0.12 | 251 | 4/16/2023 | |
3.0.11 | 290 | 3/21/2023 | |
3.0.10 | 292 | 3/9/2023 | |
3.0.9 | 281 | 3/9/2023 | |
3.0.8 | 477 | 10/13/2022 | |
3.0.7 | 526 | 9/18/2022 | |
3.0.6 | 497 | 9/10/2022 | |
3.0.5 | 473 | 9/10/2022 | |
3.0.4 | 465 | 9/10/2022 | |
3.0.3 | 497 | 9/8/2022 | |
3.0.2 | 489 | 9/8/2022 | |
3.0.1 | 748 | 7/12/2022 | |
3.0.0 | 642 | 6/20/2022 | |
2.1.5 | 541 | 6/20/2022 | |
2.1.4 | 529 | 4/19/2021 | |
2.1.3 | 469 | 4/19/2021 | |
2.1.2 | 432 | 4/18/2021 | |
2.1.1 | 505 | 4/17/2021 | |
2.1.0 | 489 | 4/17/2021 | |
2.0.2 | 521 | 1/2/2021 | |
2.0.1 | 549 | 1/2/2021 | |
2.0.0 | 489 | 12/28/2020 | |
1.0.8 | 568 | 11/5/2020 | |
1.0.7 | 570 | 8/16/2020 | |
1.0.6 | 553 | 8/10/2020 | |
1.0.5 | 533 | 8/10/2020 | |
1.0.4 | 607 | 6/20/2020 | |
1.0.3 | 585 | 6/20/2020 | |
1.0.2 | 539 | 6/17/2020 | |
1.0.1 | 620 | 5/25/2020 | |
1.0.0 | 646 | 5/24/2020 |
Restructured to be more compliant with lifetime of DbContext.