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

  • 相关阅读:
    C# 使用 Microsoft.Feeds 组件获取 RSS 全文
    使用 Jquery 做类似搜索引擎效果
    ASP.NET MVC 利用 IHttpModule 实现路由调试
    Python 爬虫类库 Selenium 的常用方法介绍
    C# 中 New 关键词的几种用法
    ASP.NET 使用 IIS URL Rewrite 模块实现伪静态
    Java 源码分析之 HashTable
    Java 类中代码块和构造方法的执行顺序
    C# 中使用 FFmpeg.NET
    C# 项目中使用 ServiceStack.Redis 操作 Redis
  • 原文地址:https://www.cnblogs.com/xcsn/p/8868207.html
Copyright © 2011-2022 走看看