zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    python鸭子类型
    chrome Network 过滤和高级过滤
    代理服务器支持https(转)
    解决fiddler不能抓取firefox浏览器包的问题(转)
    Fiddler抓包8-打断点(bpu)(转)
    Git diff (---和+++具体解释)(转)
    Xposed模块编写
    Android 渗透测试学习手册(八)ARM 利用
    Android 渗透测试学习手册(七)不太知名的 Android 漏洞
    Android 渗透测试学习手册(六)玩转 SQLite
  • 原文地址:https://www.cnblogs.com/xcsn/p/8868207.html
Copyright © 2011-2022 走看看