zoukankan      html  css  js  c++  java
  • EF延迟加载LazyLoading

    优点

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

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

    阻止延迟加载解决方案:
    1、ToList(),返回的东西是个内存级的对象,就是说强迫它在这里执行了一次SQL语句,查询到的东西被放在Web服务器内存里了,这样可以达到缓存的效果,这就阻止了延迟加载
    2、在构造函数等地方写

    ContextOptions.LazyLoadingEnabled = false;
    

    3、去掉属性里的virtual

    使用方式:两步

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

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

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

    ContextOptions.LazyLoadingEnabled = true;
    
     
     

    现象

    会在对象中产生私有字段

     
     

    其他

    贪婪加载/显示加载http://www.cnblogs.com/wlflovenet/archive/2011/07/29/EFandMvc6.html

  • 相关阅读:
    Fluent API
    什么是blazor
    10.事务
    9.用ExecuteSqlCommand执行存储过程
    8.自增主键 插入指定主键的数据
    7.图
    6.实体与上下文的关系
    5.并发
    4.跟踪
    3.级联删除
  • 原文地址:https://www.cnblogs.com/Lulus/p/7877778.html
Copyright © 2011-2022 走看看