TPC继承错误



我在使用c#实体框架Codefirst和Fluent Api时遇到了一个奇怪的TPC继承问题。我有三个类命名为Person, InvoicePeriodicInvoice,如下所示。下面是我的代码摘要:

Invoice类及其配置类:

public class Invoice : InvoiceBase
{
    public Person User { get; set; }
}
public class InvoiceConfig : EntityTypeConfiguration<Invoice>
{
    public InvoiceConfig()
    {
        this.Map(m => { m.MapInheritedProperties(); m.ToTable("Invoices"); });
    }
}

PeriodicInvoice类及其配置:

public class PeriodicInvoice : InvoiceBase
{
    // Some extra properties.
} 
public class PeriodicInvoiceConfig : EntityTypeConfiguration<PeriodicInvoice>
{
    public PeriodicInvoiceConfig()
    {
       this.Property(x => x.SuspendOnExpire).IsRequired();
       this.Map(m => { m.MapInheritedProperties(); m.toTable("PeriodicInvoices"); });
    }
}

当我运行代码时,出现以下错误:

实体类型'Invoice'和'Person'之间的关联'Invoice_User'无效。在TPC层次结构中,独立关联只允许在最派生的类型上存在。

我知道这意味着我应该将属性User包含到PeriodicInvoice类中,而不要在Invoice类中使用它。

但是,没有其他的方法来解决这个问题吗?谢谢。

在TPC继承中,你不能在父类中有一个字段指向另一个表,因为你试图将两个表指向另一个表,而一个表试图仅使用一个外键指向这两个表中的一个(这是不可能的!)

我建议你使用TPT。这个链接可以帮助你。

最新更新