EF中的预先加载和延迟加载

Posted zhangjd

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了EF中的预先加载和延迟加载相关的知识,希望对你有一定的参考价值。

延迟加载(Lazy Loading)当实体第一次被读取时,相关数据不会被获取只会读取本身。延迟加载数据不会一次性查出来,而是一条一条的查询,这样就会多次请求数据库进行查询

预先加载<Eager Loading>:预先加载会把所有的数据一次性从数据库中读取出来,预先加载就是从数据库中一次性查询所有数据,存放到内存中。

写个例子:一般我是这么处理的

1、在数据库上下文中禁用延迟加载

 

  public DBaseContext() : base("MHaloDBaseContext")
   {
        this.Configuration.LazyLoadingEnabled = false;
   }

 

因为上下文是默认延迟加载的,这样做的结果是所有的默认为预先加载。

2、下面定义一个类,说明一下

 

 public class Recruit : EntityBase
 {
     public Recruit()
      {
            IsShow = true;
      }
      public string Name { get; set; }

      public string Describe { get; set; }

      public int OrderId { get; set; }
     
      public bool IsShow { get; set; }
        
      public int JobCategoryId { get; set; }
        
      public virtual JobCategory JobCategory { get; set; }
  }

 

  在查询Recruit 这个类的时候不会加载关联类JobCategory 的相关数据,因为我们用了virtual 关键字,只有显式调用时才会加载,如果去掉virtual 关键字,关联类JobCategory 的相关数据就会被加载。

3、如果需要关联表数据则用Include() 

var list = recSvc.Res.Table()
   .Pager(filter, o => o.OrderByDescending(s => s.Id), out total, query.page, query.rows).Include(s => s.JobCategory).ToList();

查询的时候用.Include(s => s.JobCategory)就可以把相关数据查询出来。

 

以上是关于EF中的预先加载和延迟加载的主要内容,如果未能解决你的问题,请参考以下文章

EF6基础系列(九)---预先加载延迟加载显示加载

EF延迟加载

学习EF之贪婪加载和延迟加载

MVC3 EF4.1 代码优先延迟加载

学习EF之贪懒加载和延迟加载

EF 延迟加载