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的映射定义派生类型。