使用Abstract类进行列映射(带有现有表的TPT)

时间:2011-09-29 14:21:25

标签: asp.net-mvc-3 entity-framework-4 ef-code-first

我正在针对现有数据库进行开发,将我的抽象类映射到我的表作为TPT。这引发了一个错误,说“无效列名”ID“”。

简单类如下

public abstract class Member 
{
    [DisplayName("ID")]
    public string ID { get; set; }

    [DisplayName("Date Applied")]
    public System.DateTime? DateApplied { get; set; }

    [DisplayName("Date Membered")]
    public System.DateTime? DateMembered { get; set; }

    [DisplayName("Member Type")]
    public int MemberTypeFlag { get; set; }

}


public class Person : Member
{
    [DisplayName("Last Name")]
    public string LastName { get; set; }

    [DisplayName("First Name")]
    public string FirstName { get; set; }

    [DisplayName("Date Of Birth")]
    public System.DateTime DateOfBirth { get; set; }
}

并映射到我的自定义表格如下

public class MapMember : EntityTypeConfiguration<Member>
{
    public MapMember()
        : base()
    {
        HasKey(b => b.ID).Property(b => b.ID).HasColumnName("ID");
        Property(b => b.DateApplied).HasColumnName("DTM_APPLIED");
        Property(b => b.DateMembered).HasColumnName("DTM_MEMBERED");
        Property(b => b.MemberTypeFlag).HasColumnName("MBR_TYPE_FLG");
        ToTable("MBR");
    }
}

public class MapPerson : EntityTypeConfiguration<Person>
{
    public MapPerson()
        : base()
    {
        Property(p => p.LastName).HasColumnName("LNAME");
        Property(p => p.FirstName).HasColumnName("FNAME");
        Property(p => p.DateOfBirth).HasColumnName("DOB");
        Property(p => p.FirstName).HasColumnName("FNAME");
        ToTable("MBR_PERSON");
    }
}

但是db.savechanges()上引发了无效的列名“ID”。

请告知。

由于

1 个答案:

答案 0 :(得分:1)

如果MBR_PERSON表中的主键列(同时必须是MBR表的外键)没有列名ID,则会发生此错误(表MBR中的键列名称)。在TPT映射中,抽象实体的根表的主键列必须与派生实体的表的主键列具有相同的名称。