我使用EF Codefirst在自己的表中有对象。现在,我尝试为每个对象生成单独表中的已更改对象生成“归档”。
例如:
public class Person
{
[Key]
public virtual Guid Id { get; set; }
[Required]
public string Name { get; set; }
}
public class Person_Archive : Person
{
[Key]
[Columnn( Order = 1 )]
public override Guid Id { get; set; }
[Key]
[Columnn( Order = 2 )]
public DateTime ChangedAt { get; set; }
public string ChangedBy { get; set; }
}
当我让EF创建模型时, NOT 包含Person inArchive中人物的属性:-(即使我添加:
modelBuilder.Entity<Person>().ToTable( "Person" );
modelBuilder.Entity<Person_Archiv>().ToTable( "Person_Archiv" );
EF仍然不会重复派生类的属性。
有谁知道如何实现这一目标?
谢谢! 安德烈亚斯
答案 0 :(得分:4)
是的,你需要调用类似MapInheritedProperties
方法的东西来做到这一点。
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<Person>().Map(m =>
{
m.MapInheritedProperties();
m.ToTable("People");
});
modelBuilder.Entity<Person_Archieve>().Map(m =>
{
m.MapInheritedProperties();
m.ToTable("People_Archieve");
});
}
答案 1 :(得分:0)
此处为了文档而添加...如果您使用EntityTypeConfiguration来保持数据模型不具有EF特定引用,那么您需要使用EntityTypeConfiguration的Map属性,如下所示。
public class ArchivedPersonConfiguration : EntityTypeConfiguration<Person_Archieve>
{
Map(m => m.MapInheritedProperties()).ToTable("People_Archieve");
}