开发手册 欢迎您!
软件开发者资料库

Entity Framework - 显式加载

Entity Framework显式加载 - 从概述,体系结构,环境设置,数据库设置,数据模型,DbContext,类型,关系,生命周期,代码优先方法,模型第一方法,数据库第一方法,DEV方法,数据库操作,并发开始学习实体框架,事务,视图,索引,存储过程,断开连接的实体,表值函数,本机SQL,枚举支持,异步查询,持久性,投影查询,命令记录,命令拦截,空间数据类型,继承,迁移,渴望,懒惰,显式加载,验证,跟踪更改,彩色实体,第一个示例,数据注释,Fluent API,种子数据库,代码优先迁移,多个DbContext,嵌套实体类型。

当您禁用延迟加载时,仍然可以延迟加载相关实体,但必须使用显式调用完成.

  • 与延迟加载不同,在运行查询时不存在歧义或混淆的可能性.

  • 为此,请使用Load关于相关实体的条目的方法.

  • 对于一对多关系,请在Collection上调用Load方法.

  • 对于一对一的关系,请在参考上调用Load方法.

让我们看一下下面的示例,其中禁用延迟加载,然后检索名字为Ali的学生.

然后在控制台上写入学生信息.如果您查看代码,也会编写注册信息,但是尚未加载注册实体,因此不会执行foreach循环.

此后显式加载注册实体学生信息和注册信息将写在控制台窗口上.

class Program {   static void Main(string[] args) {      using (var context = new UniContextEntities()) {         context.Configuration.LazyLoadingEnabled = false;         var student = (from s in context.Students where s.FirstMidName ==             "Ali" select s).FirstOrDefault();         string name = student.FirstMidName + " " + student.LastName;         Console.WriteLine("ID: {0}, Name: {1}", student.ID, name);         foreach (var enrollment in student.Enrollments) {            Console.WriteLine("Enrollment ID: {0}, Course ID: {1}",                enrollment.EnrollmentID, enrollment.CourseID);         }         Console.WriteLine();         Console.WriteLine("Explicitly loaded Enrollments");         Console.WriteLine();         context.Entry(student).Collection(s ⇒ s.Enrollments).Load();         Console.WriteLine("ID: {0}, Name: {1}", student.ID, name);         foreach (var enrollment in student.Enrollments) {            Console.WriteLine("Enrollment ID: {0}, Course ID: {1}",                enrollment.EnrollmentID, enrollment.CourseID);         }         Console.ReadKey();      }   }}

执行上述示例时,您将收到以下输出.首先显示学生信息,并在显式加载注册实体后,显示学生及其相关注册信息.

ID: 1, Name: Ali AlexanderExplicitly loaded EnrollmentsID: 1, Name: Ali Alexander       Enrollment ID: 1, Course ID: 1050       Enrollment ID: 2, Course ID: 4022       Enrollment ID: 3, Course ID: 4041

我们建议您逐步执行上述示例,以便更好地理解.