EF---延迟加载技术


延迟加载:

优点:只在需要的时候加载数据,不需要预先计划,避免了各种复杂的外连接、索引、视图操作带来的低效率问题

使用方式:两步

第一:在需要延迟加载的属性前加上virtual ,该属性的类型可以是任务的集合类型ICOLLOCT<T>或者是0/1..1关联属性。

如: public virtual List<Product> Products { get; set; }

第二:在context构造器中开启延迟加载功能

 ContextOptions.LazyLoadingEnabled = true;

 

缺陷:多次与DB交互,性能降低

阻止延迟加载解决方案:

ToList(),返回的东西是个内存级的对象,就是说强迫它在这里执行了一次SQL语句,查询到的东西被放在Web服务器内存里了,这样可以达到缓存的效果,这就阻止了延迟加载

 

 

 

参考:

tks:

http://www.cnblogs.com/sunrfun/archive/2011/05/11/2043053.html

http://wenku.baidu.com/view/ddcd122ab4daa58da0114af6.html


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM