Entity Framework 中把LazyLoadingEnabled设置为了false,为何仍然是懒加载模式?

发布于 2022-09-03 14:36:36 字数 1216 浏览 16 评论 0

在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有值,必须要显示调用吗?
        }

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

哭泣的笑容 2022-09-10 14:36:36

db.Configuration.LazyLoadingEnabled = false;
db.Configuration.AutoDetectChangesEnabled = false;
db.Configuration.ProxyCreationEnabled = false;
db.Configuration.ValidateOnSaveEnabled = false;

这几个代码要写在DBContext文件里。你放在Using(){}里面是不会起作用的。

暗恋未遂 2022-09-10 14:36:36

我把
db.Configuration.LazyLoadingEnabled = false;
db.Configuration.AutoDetectChangesEnabled = false;
db.Configuration.ProxyCreationEnabled = false;
db.Configuration.ValidateOnSaveEnabled = false;
放在KLGContext的构造函数里也没有效果。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文