使用C#实体框架、Codefirst和Fluent Api进行TPC继承时,我遇到了一个奇怪的问题。我有3个类,名为Person、Invoice和PeriodicInvoice,如下所示。下面是我的代码摘要:
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_User”无效。在TPC层次结构中,只有在大多数派生类型上才允许独立的关联。
我知道这意味着我应该将属性User包含到类PeriodicInvoice中,而不是在类Invoice中使用它。
但是,没有其他方法可以解决这个问题吗?谢谢。
发布于 2015-07-09 16:52:31
在TPC继承中,不能在父类中有一个指向另一个表的字段,因为您试图将两个表指向另一个表,而一个表试图使用一个外键指向这两个表中的一个(这是不可能的!)
我建议你用TPT。这个链接可以帮你。
https://stackoverflow.com/questions/31315158
复制相似问题