EF4和多个抽象级别

Ced*_*ric 8 c# inheritance entity-framework entity-framework-4

我需要使用EF4继承和从DB创建的TPH模型.
我创建了一个新的项目来测试简单类.有我的班级模型:

在此输入图像描述

SQL SERVER 2008中有我的表:

VEHICLE 
  ID : int PK
  Owner : varchar(50)
  Consumption : float
  FirstCirculationDate : date
  Type : varchar(50)
  Discriminator : varchar(10)
Run Code Online (Sandbox Code Playgroud)

我在Discriminator字段的EDMX中添加了一个条件,以区分Scooter,Car,Motorbike和Bike实体.

MotorizedVehicle和Vehicle是抽象的.

但是当我编译时,会出现此错误:

错误3032:从第78,85行开始映射片段时出现问题:EntityTypes EF4InheritanceModel.Scooter,EF4InheritanceModel.Motorbike,EF4InheritanceModel.Car,EF4InheritanceModel.Bike被映射到表Vehicle中的相同行.映射条件可用于区分这些类型映射到的行.

编辑:
致Ladislav:
我尝试了它并且错误更改为我的所有实体:

错误3034:从第72,86行开始映射片段时出现问题:实体映射到同一个表中的>不同行.确保这两个映射片段不会将具有重叠键的两个>实体组映射到两个不同的行组.

致Henk(有Ladislay建议):
有所有映射细节: 在此输入图像描述 在此输入图像描述 在此输入图像描述 在此输入图像描述 在此输入图像描述 在此输入图像描述

怎么了 ?

谢谢

Jon*_*ams 1

EF4 不能很好地处理这些问题。您可以使用判别器来做到这一点,但类必须是非抽象的。您必须使用另一种方法(例如代码分析或测试)来确保基类永远不会由实体框架之外的任何其他方法实例化。

或者,您可以升级到 EF6。我不确定它是否会更好地支持它,但它肯定可以更好地处理模型层次结构,从而允许更好的数据库模式更好地支持模型。