簡體   English   中英

實體類型 List 需要定義一個主鍵

[英]The entity type List requires a primary key to be defined

我使用 .NET 5 和實體框架作為 ORM。 我想使用代碼優先的數據庫方法。

我有 2 個實體類:

public class PurchaseOrderItem
{
    public int Id { get; set; }
    public string Name { get; set; }
    public double Price { get; set; }

    [ForeignKey("PurnchaseOrder")]
    public int PurnchaseOrderId { get; set; }
    public PurchaseOrder PurchaseOrder { get; set; }
}

public class PurchaseOrder
{
    public int Id { get; set; }
    public string Name { get; set; }
    public DateTime  CreationDate { get; set; }
    public List<PurchaseOrderItem> PurchaseOrderItems { get; set; }

    [NotMapped]
    public double TotalPrice
    {
        get
        {
            return PurchaseOrderItems.Sum(x => x.Price);
        }
    }
}

但是當我嘗試添加新的遷移時,我收到如下錯誤:

實體類型“列表”需要定義一個主鍵。 如果您打算使用無密鑰實體類型,請在“OnModelCreating”中調用“HasNoKey”。 有關無密鑰實體類型的詳細信息,請參閱https://go.microsoft.com/fwlink/?linkid=2141943

還有我的數據庫上下文類:

public class ItemsAppDbContext : DbContext
{
    public ItemsAppDbContext(DbContextOptions options) : base(options)
    {
    }

    public DbSet<AppUser> Users { get; set; }
    public DbSet<PurchaseOrderItem> PurchaseOrderItems { get; set; }
    public DbSet<PurchaseOrder> PurchaseOrders { get; set; }

    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        modelBuilder.Entity<PurchaseOrder>()
                    .HasOne(p => p.PurchaseOrderItems)
                    .WithMany()
                    .OnDelete(DeleteBehavior.Cascade);
    }
}

在您的 ItemsAppDbContext 中更新以下代碼

protected override void OnModelCreating(ModelBuilder modelBuilder)
{
    modelBuilder.Entity<PurnchaseOrder>()
    .HasMany(p => p.PurnchaseOrderItems)
    .WithOne(g => g.PurnchaseOrder).HasForeignKey(s=>s.PurnchaseOrderId)
    .OnDelete(DeleteBehavior.Cascade);
}

閱讀本文以了解更多信息。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

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