在带有 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/