1

有这些:

class Base
{
  public int ID {get;set;}
}

class DerivedA : Base
{
}

class DerivedB : Base
{
}

...

然后我可以像这样设置公共主键:

builder.EntityType<Base>().HasKey(m => m.ID);

但是,当我这样做时,每个派生类型都会被映射,这由于各种原因是不可取的,一个是我有几十个派生类型。耐心地,我试图忽略每一个我不想要的,我最终得到了这个错误:

The sequence contains more than one element
   at System.Linq.Enumerable.SingleOrDefault[TSource](IEnumerable`1 source, Func`2 predicate)
   at System.Web.OData.Builder.ODataConventionModelBuilder.RemoveBaseTypeProperties(StructuralTypeConfiguration derivedStructrualType, StructuralTypeConfiguration baseStructuralType)
   at System.Web.OData.Builder.ODataConventionModelBuilder.DiscoverInheritanceRelationships()
   at System.Web.OData.Builder.ODataConventionModelBuilder.GetEdmModel()

我确实相信这些忽略最终会以某种方式相互重叠。我只是无法为它们中的每一个微调一个忽略块。到目前为止唯一有效的是将 ID 属性重新定义为每个派生类的新属性,这几乎违背了基类的全部目的。

有什么提示吗?

4

1 回答 1

1

有很多事情要考虑,我没有从多次试验和错误中看到的一个遗留问题是,除了基类的 ID 映射之外,我还为派生类映射了相同的 ID:

builder.EntityType<Base>().HasKey(m => m.ID);
...
(in another class far far away)
builder.EntityType<DerivedA>().HasKey(m => m.ID);
builder.EntityType<DerivedB>().HasKey(m => m.ID);

我删除了派生类上的键映射,只留下基类上的键映射,一切正常。所以我想这与忽略无关。

多么神秘的通用错误消息……

我用这个新信息更新了一篇博文,查看它以获取更多信息,包括如何忽略派生类型。

于 2015-01-08T14:39:02.863 回答