entity framework代码首先将多个相同类型的复杂类型映射到表

如果您有以下域模型:

public class Test { public string Description { get; set; } public TestB A { get; set; } public TestB B { get; set; } public TestB C { get; set; } } public class TestB { public string Name { get; set; } public string Description { get; set; } } 

你有一个具有以下结构的表:

 Test - Description - NameA - DescriptionA - NameB - DescriptionB - NameC - DescriptionC 

名称和描述对映射到复杂类型B的单个实例。

假设数据库模式无法更改,有没有办法纯粹使用流畅的API定义此映射?

我以合理的方式使用它的唯一方法是派生TestB的子类型并将它们映射为:

  modelBuilder.ComplexType().Property(x => x.Name).HasColumnName("NameA"); modelBuilder.ComplexType().Property(x => x.Description).HasColumnName("DescriptionA"); modelBuilder.ComplexType().Property(x => x.Name).HasColumnName("NameB"); modelBuilder.ComplexType().Property(x => x.Description).HasColumnName("DescriptionB"); 

我宁愿不必纯粹为entity framework的映射定义派生类型。