前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >代码看不懂?ChatGPT 帮你解释,详细到爆!

代码看不懂?ChatGPT 帮你解释,详细到爆!

作者头像
生信宝典
发布2023-08-30 12:22:04
1810
发布2023-08-30 12:22:04
举报
文章被收录于专栏:生信宝典生信宝典

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

Entity Framework Plus

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

功能特性

批量删除

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

代码语言:javascript
复制
// 删除所有 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);

批量更新

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

查询过滤

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

代码语言:javascript
复制
QueryFilterManager.Filter<Post> 
    (q => q.Where(x => !x.IsSoftDeleted)); 

var ctx = new EntitiesContext(); 

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

查询缓存

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

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

代码语言:javascript
复制
// (EF5 | EF6) 2 个小时的查询缓存
var states = ctx.States.Where(x => x.IsActive).FromCache(DateTime.Now.AddHours(2));
代码语言:javascript
复制
// 两个小时的滑动过期
var options = new MemoryCacheEntryOptions() { SlidingExpiration = TimeSpan.FromHours(2)};
var states = ctx.States.Where(x => x.IsActive).FromCache(options);
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2023-07-25,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 生信宝典 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档