![](/img/trans.png)
[英]ASP.NET Core 2.0 MVC EF One-to-Many and Many-to-Many relationship
[英]One-to-Many EF .NET Core Relationship Not Working
我有一个 .net 核心 api 应用程序,其中包括用于检索数据的 EF。 我已经设置了一个数据上下文,我可以从数据库中获取 map 表。 当我尝试建立关系时,尽管我总是为嵌套的 object 返回 null。
我有一个“机会” class ,其中包含一个 ICollection 的“Notes”
public class Opportunity
{
public int Id { get; set; }
public string Name { get; set; }
...
public decimal FinalDealProfit { get; set; }
public ICollection<CRMNote> CRMNotes { get; set; }
}
以及引用机会的注释 class :
public class CRMNote
{
public int Id { get; set; }
public int OpportunityId { get; set; }
public string Note { get; set; }
public string User { get; set; }
public DateTime DateTime { get; set; }
public string FilePath { get; set; }
public Opportunity Opportunity { get; set; }
}
在我的上下文中 class 具有以下设置:
modelBuilder.Entity<Opportunity>(entity =>
{
entity.ToTable("CRM_Opportunity");
entity.HasMany<CRMNote>(n => n.CRMNotes)
.WithOne(t => t.Opportunity)
.HasForeignKey(k => k.OpportunityId);
});
我也一直在映射 Note class:
modelBuilder.Entity<CRMNote>(entity =>
{
entity.ToTable("CRM_Note");
//entity.HasOne<Opportunity>(t => t.Opportunity)
// .WithMany(p => p.CRMNotes)
// .HasForeignKey(k => k.OpportunityId);
});
如您所见,我一直在研究如何将实体连接在一起。
每当我检索到机会时,notes 数组总是 null。 我尝试在 Opportunity class 上放置一个空的构造函数:
public Opportunity()
{
CRMNotes = new List<CRMNote>();
}
但这只是意味着我得到一个空数组而不是 null。
我看不到我错过了什么。 我已经检查了它的文档:
https://www.entityframeworktutorial.net/efcore/one-to-many-conventions-entity-framework-core.aspx
但显然我错过了一些东西。 非常感谢任何帮助,因为这应该是一件容易的事,但显然有些事情让我望而却步。
常用的 O/RM 模式有 3 种用于加载相关数据 Eager loading、Explicit loading 和 Lazy loading
例如,在急切加载中,您可以使用:
var opportunities=context.opportunities.Include(opportunity=>opportunity.CRMNotes).ToList()
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.