• EF的三种数据加载方式


    EF的关联实体加载有三种方式:Lazy Loading,Eager Loading,Explicit Loading,其中Lazy LoadingExplicit Loading都是延迟加载。

    (一)延迟加载(默认):Lazy Loading使用的是动态代理,默认情况下,如果POCO类满足以下两个条件,EF就使用Lazy Loading:

    1. POCO类是Public且不为Sealed。
    2. 导航属性标记为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

  • 相关阅读:
    golang gc
    set password to qcow2
    golang reflect struct
    Mac 自启动管理
    shell exec
    shell 管道 与 mkfifo
    shell 读取文件
    shell 函数
    shell read 命令
    ubuntu 快速安装和设置 mysql
  • 原文地址:https://www.cnblogs.com/xcsn/p/8868207.html
Copyright © 2020-2023  润新知