EF的关联实体加载有三种方式:Lazy Loading,Eager Loading,Explicit Loading,其中Lazy Loading和Explicit Loading都是延迟加载。
(一)延迟加载(默认):Lazy Loading使用的是动态代理,默认情况下,如果POCO类满足以下两个条件,EF就使用Lazy Loading:
- POCO类是Public且不为Sealed。
- 导航属性标记为Virtual。
关闭Lazy Loading,可以将LazyLoadingEnabled设为false,如果导航属性没有标记为virtual,Lazy Loading也是不起作用的。
(二)贪婪加载:不设置导航属性为virtual,并且对导航属性使用Include,Eager Loading使用Include方法关联预先加载的实体。
(三)显示加载:不设置导航属性为virtual,并且对导航属性使用Reference(单个对象).Load()或Collection(对象集).Load()。Explicit Loading使用Entry方法,对于集合使用Collection,单个实体则使用Reference。
public class Programm { public static void Main() { TestDbContext db = new TestDbContext(); //延迟加载 var res1 = db.Reservations; foreach (var item in res1) { //do something } //贪婪加载 //有多个Include会全部完成加载,生成的sql命令是一条完成的 var res2 = db.Reservations.Include(r => r.Details); //显示加载 var res3 = db.Reservations.ToList(); foreach (var item in res3) { var temp = db.Entry(item); temp.Collection(i => i.Details).Load(); temp.Reference(i => i.Customer).Load(); } } } public class Reservation { public int ReservationId { get; set; } public string ClientName { get; set; } public string Location { get; set; } public List<ReservationDetails> Details { get; set; } public Customer Customer { get; set; } } public class ReservationDetails { public int Id { get; set; } public DateTime Time { get; set; } } public class Customer { public int Id { get; set; } public string Name { get; set; } } public class TestDbContext : DbContext { public DbSet<Reservation> Reservations { get; set; } }
暂时COPY记录,有空再整理
原文:
http://www.cnblogs.com/peaceSouth/p/5813646.html
https://www.cnblogs.com/liangxiaofeng/p/5809301.html
http://www.cnblogs.com/nianming/archive/2013/01/09/2846952.html