gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-04 06:43:34 26 4
gpt4 key购买 nike

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

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com