一对多EF .NET核心关系不起作用

时间:2020-05-27 09:17:09

标签: entity-framework .net-core

我有一个.net核心api应用程序,其中包括EF来检索数据。我已经建立了数据上下文,并且可以从db映射表。当我尝试建立关系时,嵌套对象总是返回null。

我有一个“机会”类,其中包含一个“便笺”的ICollection

public class Opportunity
{
    public int Id { get; set; }
    public string Name { get; set; }
    ...
    public decimal FinalDealProfit { get; set; }
    public ICollection<CRMNote> CRMNotes { get; set; }
}

和一个引用机会的Note类:

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; }
}

在我的上下文类中,进行以下设置:

modelBuilder.Entity<Opportunity>(entity =>
  {
    entity.ToTable("CRM_Opportunity");
    entity.HasMany<CRMNote>(n => n.CRMNotes)
      .WithOne(t => t.Opportunity)
      .HasForeignKey(k => k.OpportunityId);
    });

我也一直在映射Note类:

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类上放置一个空的构造函数:

public Opportunity()
  {
    CRMNotes = new List<CRMNote>();
  }

但这只是意味着我得到的是空数组而不是null。

我看不到我错过的一切。我已经检查了文档:

https://www.entityframeworktutorial.net/efcore/one-to-many-conventions-entity-framework-core.aspx

但是很明显我错过了一些东西。任何帮助都值得赞赏,因为这应该是一件容易的事,但显然我无法理解。

1 个答案:

答案 0 :(得分:1)

有三种常见的O / RM模式用于加载相关数据 渴望加载, 显式加载 和 延迟加载

例如,在急切加载中,您可以使用:

var opportunities=context.opportunities.Include(opportunity=>opportunity.CRMNotes).ToList()