zoukankan      html  css  js  c++  java
  • Entity Framework Tutorial Basics(38):Explicit Loading

    Explicit Loading with DBContext

    Even with lazy loading disabled, it is still possible to lazily load related entities, but it must be done with an explicit call. Use the Load method of DBEntityEntry object to accomplish this.

    The following code explicitly loads Standard of particular Student using the Reference() method of DbEntityEntry:

    using (var context = new SchoolDBEntities())
    {
        //Disable Lazy loading
        context.Configuration.LazyLoadingEnabled = false;
                    
        var student = (from s in context.Students
                            where s.StudentName == "Bill"
                            select s).FirstOrDefault<Student>();
    
        context.Entry(student).Reference(s => s.Standard).Load();
    }     

    If you run the code shown above, you can see that it first loads student but not standard, as shown below:

    Entity Framework tutorial 4.3 dbcontext

    The load method to get the Standard entity is shown below:

    Entity Framework tutorial 4.3 dbcontext

    The code shown above will execute two different database queries. The first query gets Student and the second query gets Standard.

    Load collection:

    Use the Collection() method instead of Reference() method to load collection navigation property. The following example loads the courses of student.

    using (var context = new SchoolDBEntities())
    {
        context.Configuration.LazyLoadingEnabled = false;
                    
        var student = (from s in context.Students
                            where s.StudentName == "Bill"
                            select s).FirstOrDefault<Student>();
    
        context.Entry(student).Collection(s => s.Courses).Load();
    }

    Note: The Load extension method works just like ToList, except that it avoids the creation of the list altogether.

  • 相关阅读:
    Python进程、线程
    Maven项目的坐标GroupId和ArtifactId
    java中的变量
    java中new一个对象的执行过程及类的加载顺序
    java中string和int互相转化
    什么是设计模式?
    Mybatis解决了JDBC编程哪些问题
    SQL注入、占位符拼接符
    JDBC、事务和连接池
    关于Spring配置文件xml文档的schema约束
  • 原文地址:https://www.cnblogs.com/purplefox2008/p/5649436.html
Copyright © 2011-2022 走看看