码迷,mamicode.com
首页 > 其他好文 > 详细

EF中的延迟加载和贪婪加载

时间:2015-01-06 11:44:30      阅读:274      评论:0      收藏:0      [点我收藏+]

标签:

延迟加载:

优点:

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

使用方式:

      第一:

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

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

      第二:

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

                 ContextOptions.LazyLodingEnabled = true;

缺点:

       多次与数据库交互,性能降低

阻止延迟加载解决方案:

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

EF中的延迟加载和贪婪加载

标签:

原文地址:http://www.cnblogs.com/FredWang/p/4205456.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!