怎么采用EntityFramework.Extended 对EF进行扩展
怎么采用EntityFramework.Extended 对EF进行扩展
怎么采用EntityFramework.Extended 对EF进行扩展,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
前言
今天我们来讲讲EntityFramework.Extended
首先科普一下这个EntityFramework.Extended是什么,如下:
这是一个对Entity Framework进行扩展的类库.
完全支持EF 5.0/6.0+,
GitHub地址https://github.com/loresoft/EntityFramework.Extended,
最后一次更新是在2015/07/10
这个库支持批量更新,删除。查询结果缓存和审计日志。
这个扩展对于每次批量操纵只生成一条sql语句,而不会像EntityFramework供给的原生办法那样批量N条数据就要生成N条sql语句
采用的环境与技术
系统:WIN7
数据库:SQL Server2008
相关技术:MVC5+EF6.1.3+EntityFramework.Extended6.0
第一章:批量操作数据库
批量删除:
//记得引用usingEntityFramework.Extensions;//这两种写法都可以,Context是你的EF上下文对象.context.LogData.Delete(a=>a.EntityKey=="aa");context.LogData.Where(a=>a.EntityKey=="aa").Delete();
批量更新:
//data为修改的行数intdata=context.LogData.Where(a=>a.EntityKey=="aa").Update(b=>newLogData{EntityName="ss"});//第二种写法,这种是针对DbSet的,已经标注过时了vardata=context.LogData.Update(a=>a.EntityKey=="aa",b=>newLogData{EntityName="ss"});
批量增加:
//这个和Extended无关..EF本身就自带了,单纯的给新手一个实例而已,大神无视..intdata=context.LogData.AddRange(newList<LogData>());
第二章:批量查询数据库
原理是这样的:
E文原文:
Future queries work by creating the appropriate IFutureQuery object that keeps the IQuerable. The IFutureQuery object is then stored in IFutureContext.FutureQueries list. Then, when one of the IFutureQuery objects is enumerated, it calls back to IFutureContext.ExecuteFutureQueries() via the LoadAction delegate. ExecuteFutureQueries builds a batch query from all the stored IFutureQuery objects. Finally, all the IFutureQuery objects are updated with the results from the query.
小编的辣鸡二流子翻译:
Future 会根据IQuerable创建出他自定义的IFutureQuery对象,然后将他加入到IFutureContext.FutureQueries查询队列当中,当队列中的一个对象调用LoadAction那么就会执行IFutureContext.ExecuteFutureQueries()方法,ExecuteFutureQueries 会构建一个批处理查询的IFutureQuery,最后将所有IFutureQuery的查询结果进行更新(也就是查询).
第三章:EF的数据审计日志
数据审计日志:
先说一下这个审计的概念,就是对所有的实体的操作(增,删,改)进行监控.
这是他追踪到的信息,我们可以很方便的把这些信息存入数据库或者你的日志存储里(文本,XML,缓存)都行 随你.
下面我们开始讲解用法:
首先我们可以在应用程序的入口(Application_Start)配置(我这里以MVC的Web应用来举例):
这里的配置可不加,用默认的也行。
关于怎么采用EntityFramework.Extended 对EF进行扩展问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。
推荐阅读
-
Web应用从零开始,初学者友好型开发教程
-
容器化最佳实践:Docker 与 Kubernetes 在微服务架构中的协同设计
-
AWS Cloud9 使用攻略:云端 IDE 如何无缝集成 Lambda 与 S3 服务?
-
Heroku vs AWS Elastic Beanstalk:快速部署 Web 应用的平台对比
-
Kubernetes 集群部署避坑:资源调度、服务发现与滚动更新策略
-
Docker 镜像优化指南:分层构建、瘦身技巧与多阶段编译实践
-
Postman 接口测试全流程:从 API 设计到自动化测试脚本编写
-
pytest 框架进阶:自定义 fixture、插件开发与持续集成集成方案
-
JUnit 5 新特性:参数化测试、扩展模型与微服务测试实践
-
Chrome DevTools 性能分析:FPS 监控、内存快照与网络请求优化指南