前言
Entity Framework 延伸系列目录
今天我们来讲讲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
第一章:批量操作数据库
批量删除:
批量更新:
批量增加:
第二章:批量查询数据库
批量查询:
原理是这样的:
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应用来举例):
这里的配置可不加,用默认的也行,当然有需要的可以参考
https://github.com/loresoft/EntityFramework.Extended/wiki/Audit-Log
这里有更详细的配置介绍
下面我们开始直接用,
举个栗子:
最终结果如下:
可以看到我们很方便的监控到了我们刚刚进行的三次操作.
(重要提示:这里需要注意的是,这里的审计日志只能监控到常规的写法的增删改,对于上面的批量增删改很诡异的是监控不到的,作为自己写的扩展库,自己却监控不到 - -,这不得不说是很蛋疼..)
第四章:查询缓存
代码如下:
这个我用的不多,就不详细的赘述了,有兴趣的朋友可以自行查看
https://github.com/loresoft/EntityFramework.Extended/wiki/Query-Result-Cache
写在最后
文章到此就结束了,写文章的过程也是自己温故而知新的过程.写的不好希望大神多多指正,我很希望能起到抛砖引玉的效果,上篇文章就得到了很多好的建议,希望大家不啬赐教.
作者:顾振印
出处:http://www.cnblogs.com/GuZhenYin/
如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面