asp.net-mvc-3 - 如何在 Entity Framework 中更新实体的导航属性

标签 asp.net-mvc-3 entity-framework ef-code-first dbcontext navigation-properties

在带有 Entity Framework 的ASP .NET MVC 3中,我有一个域对象,该对象具有一个导航属性,该导航属性引用了另一个对象,如下所示:

public class Person
{
    public String Name {get;set;}

    public Guid CompanyID{get;set;}

    [ForeignKey(CompanyID)]
    public virtual CompanyType Company{ get; set; }
}

当我创建Person实例并尝试将其添加到数据库时,DBContext会保留此实体“Person”的缓存并将其发送到数据库。因此,在同一个上下文实例的生存期内,当我尝试访问该实体时,“公司”字段始终为空,因为导航属性从未更新。

有没有一种方法可以使用数据库中存在的内容来更新导航属性?

延迟加载已打开。

最佳答案

如果启用了延迟加载,并且您想使用延迟加载来加载导航属性,则必须创建新Person的代理,而不是使用new实例化它,如下所示:

using (var context = new MyDbContext())
{
    var person = context.People.Create(); // creates a lazy loading proxy
    person.CompanyID = 123;
    context.People.Add(person);
    context.SaveChanges();

    var company = person.Company; // lazy loading query happens here
}

如果没有延迟加载,则可以使用显式加载:
using (var context = new MyDbContext())
{
    var person = new Person();
    person.CompanyID = 123;
    context.People.Add(person);
    context.SaveChanges();

    context.Entry(person).Reference(p => p.Company).Load(); // explicit loading

    var company = person.Company; // no query anymore, Company is already loaded
}

关于asp.net-mvc-3 - 如何在 Entity Framework 中更新实体的导航属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10542209/

相关文章:

c# - 带模型的 mvc 上传文件 - 第二个参数发布的文件为空

c# - 在 asp.net mvc 3 中的 html 帮助器类的控件或扩展方法中包含 js/css 文件

c# - ASP.NET MVC 5 Identity with Model First

c# - EF6 代码第一个多重一对多映射问题/"Multiplicity"错误

javascript - 在MVC 3中使用Url.Content加载JS文件

asp.net-mvc - 没有 [required] 属性的 Razor 验证触发

c# - Entity Framework 中的 Skip() 和 Take()

c# - 在 UnitOfWork 中存储对通用存储库的引用

entity-framework - "Error getting value from ' MyEntity ' on ' System.Data.Entity.DynamicProxies...”

mysql - Entity Framework Code First - MySQL - 错误找不到表