簡體   English   中英

一對多 EF .NET 核心關系不工作

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM