在 EF6.0 版本中,我把 LazyLoadingEnabled 设置为了 false ,但在查询一个具有导航属性的实体时,这个查询出来的实体其导航属性仍然为空,不知道为何会是这样的行为?
我想实现“饥渴加载”模式,在查询的时候不想显示调用 Include 、 Reference 以及 Collection 方法,就可以把实体的相关导航属性全部一次性加载进来,应该如何做呢? 主要代码如下:
[Table("Departments")]
public class Department
{
[Key]
public int DeptID { get; set; }
public string Name { get; set; }
public virtual ICollection<Employee> Employees { get; set; }
}
[Table("Employees")]
public class Employee
{
[Key]
public int EmpID { get; set; }
public string Name { get; set; }
public int DeptID { get; set; }
public virtual Department Department { get; set; }
}
using (var db = new KLGContext())
{
db.Configuration.LazyLoadingEnabled = false;
db.Configuration.AutoDetectChangesEnabled = false;
db.Configuration.ProxyCreationEnabled = false;
db.Configuration.ValidateOnSaveEnabled = false;
var d1 = db.Department.ToArray();
var e1 = d1.First().Employees;//关闭了懒加载模式, e1 为何还是 null ?
var d2 = db.Department.Include("Employees").ToArray();
var e2 = d2.First().Employees;//显示调用上面的 Include 后, e2 有值,必须要显示调用吗?
}
1
rexxiang 2016-09-08 19:16:45 +08:00
必须显式的 include ,不然,有可能 load 一个对象都有可能把整个 db 都 load 出来么。。。
|
2
Dic4000 OP @rexxiang 那为何 EF 会有这个属性,我把它设置为 false ,就没有什么效果吗?反正都是延迟(懒)加载模式,不提供这个属性也可以啊。
|
3
levon 2016-09-08 20:36:56 +08:00
去掉属性的 virtual 修饰符试试
|