簡體   English   中英

EF Codefirst如何為派生類創建單獨的表?

[英]EF Codefirst How to create separate table for derived class?

我使用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創建模型包括人的性質Person_Archive :-(即使我補充一下:

modelBuilder.Entity<Person>().ToTable( "Person" );
modelBuilder.Entity<Person_Archiv>().ToTable( "Person_Archiv" );

EF仍然不會重復派生類的屬性。

有誰知道如何實現這一目標?

謝謝! 安德烈亞斯

是的,你需要調用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");
    });            
}

為了文檔而添加這里...如果您使用EntityTypeConfiguration來保持您的數據模型不具有EF特定引用,那么您需要使用EntityTypeConfiguration的Map屬性,如下所示。

public class ArchivedPersonConfiguration : EntityTypeConfiguration<Person_Archieve>
{
    Map(m => m.MapInheritedProperties()).ToTable("People_Archieve");
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM