EF延迟加载LazyLoading
生活随笔
收集整理的这篇文章主要介绍了
EF延迟加载LazyLoading
小编觉得挺不错的,现在分享给大家,帮大家做个参考.
优点
只在需要的时候加载数据,不需要预先计划,避免了各种复杂的外连接、索引、视图操作带来的低效率问题
缺陷:多次与DB交互,性能降低
阻止延迟加载解决方案:
1、ToList(),返回的东西是个内存级的对象,就是说强迫它在这里执行了一次SQL语句,查询到的东西被放在Web服务器内存里了,这样可以达到缓存的效果,这就阻止了延迟加载
2、在构造函数等地方写
3、去掉属性里的virtual
使用方式:两步
第一:在需要延迟加载的属性前加上virtual ,该属性的类型可以是任务的集合类型ICOLLOCT<T>或者是0/1..1关联属性。
如:
第二:在context构造器中开启延迟加载功能
ContextOptions.LazyLoadingEnabled = true;现象
会在对象中产生私有字段
其他
贪婪加载/显示加载http://www.cnblogs.com/wlflovenet/archive/2011/07/29/EFandMvc6.html
转载于:https://www.cnblogs.com/Lulus/p/7877778.html
总结
以上是生活随笔为你收集整理的EF延迟加载LazyLoading的全部内容,希望文章能够帮你解决所遇到的问题。
- 上一篇: 路程一共25千米 自行车先走了20千米
- 下一篇: md5 破解网站