EntityFramework-Plus: 让 EF Core 如虎添翼

31939a2bb573ccf4f6dbf31aef28fb9b.png

0632e0ea90703cf8c60ae9a55c222e49.gif

f66d5fd8d7c815ad306d8b41d9df5955.png

欢迎来到 Dotnet 工具箱!在这里,你可以发现各种令人惊喜的开源项目!

Entity Framework Plus

Entity Framework Plus 是一个用于增强 EF6 和 EF Core 的免费开源库。它对您的数据库上下文 DbContext 进行了扩展,包括过滤器、审核、缓存、批量删除、批量更新等。

功能特性

批量删除

使用 LINQ 直接删除实体,并需在上下文中加载实体。支持设置批处理大小来提高性能。

// 删除所有 2 年内不活动的用户
var date = DateTime.Now.AddYears(-2);
ctx.Users.Where(x => x.LastLoginDate < date)
    .Delete();

// 使用 BatchSize 进行删除
var date = DateTime.Now.AddYears(-2);
ctx.Users.Where(x => x.LastLoginDate < date)
    .Delete(x => x.BatchSize = 1000);

批量更新

//  更新所有两年内不活动的用户
var date = DateTime.Now.AddYears(-2);
ctx.Users.Where(x => x.LastLoginDate < date)
    .Update(x => new User() { IsSoftDeleted = 1 });

查询过滤

下面的示例中,过滤了软删除记录

QueryFilterManager.Filter<Post> 
    (q => q.Where(x => !x.IsSoftDeleted)); 

var ctx = new EntitiesContext(); 

// SELECT * FROM Post WHERE IsSoftDeleted = false 
var list = ctx.Posts.ToList();

查询缓存

查询的结果从缓存中返回,如果查询时没有缓存,会查询数据库并进行缓存。

可以指定缓存策略和缓存标签来控制缓存过期。

// (EF5 | EF6) 2 个小时的查询缓存
var states = ctx.States.Where(x => x.IsActive).FromCache(DateTime.Now.AddHours(2));
// 两个小时的滑动过期
var options = new MemoryCacheEntryOptions() { SlidingExpiration = TimeSpan.FromHours(2)};
var states = ctx.States.Where(x => x.IsActive).FromCache(options);

-

技术群:添加小编微信并备注进群

小编微信:mm1552923   

公众号:dotNet编程大全    

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值