2

我正在尝试在 EntityFramework Code First 中映射以下继承

public class Member
{
    public string ProjectName { get; set; }
    public string AssemblyName { get; set; }
    public string NamespaceName { get; set; }
    public string TypeName { get; set; }
    public string Signature { get; set; }
    public string DisplayName { get; set; }
    public MemberType Type { get; set; }
    public string Summary { get; set; }
    public bool IsStatic { get; set; }
    public bool IsInherited { get; set; }

    //public virtual Type ParentType { get; set; } // ignore this
}

public class Field : Member
{
    public string ValueType { get; set; }
    public bool IsReadOnly { get; set; }
    public bool IsVolatile { get; set; }
}

public enum MemberType
{
    Constructor,
    Field,
    Method,
    Operator,
    Property
}

正如您可能从代码中猜到的那样,我计划及时添加更多成员的子类(命名为构造函数、方法、运算符和属性),但首先我只想让字段一个正常工作。

我的映射代码看起来像这样

modelBuilder.Entities<Member>().Configure(config =>
{
    config.HasKey(m => new { m.ProjectName, m.AssemblyName, m.NamespaceName, m.TypeName, m.Signature });
    config.Property(m => m.DisplayName).IsRequired();
    config.ToTable("Members");
});

modelBuilder.Entities<Field>().Configure(config =>
{
    config.HasKey(f => new { f.ProjectName, f.AssemblyName, f.NamespaceName, f.TypeName, f.Signature });
});

modelBuilder.Entity<Member>()
    .Map<Field>(m => 
    {
        m.ToTable("Fields");
        m.Requires("Type").HasValue((int)Service.DataTypes.MemberType.Field).IsRequired();
    }); // note: realy not certain about this one

我想要的是生成两个表。一个名为“Members”,一个名为“Fields”,并使用 -class 中的Type-propertyMember作为鉴别器,我确定我只是在这里做一些非常愚蠢的事情,但我不能为我的生命出来怎么做。因为使用当前代码,它会在“字段”表中生成一个名为“类型”的列,您显然不需要它,因为它是一个常量。

所以我只是想知道,有人能告诉我我到底做错了什么吗?

4

1 回答 1

0

那里有错字吗?您的班级有一个字段 Valuetype Not Type。

我从未尝试过使用 JUST 1 映射,请尝试使用第二张表来确保。

modelBuilder.Entity<Member>()
.Map<Field>(m => 
{
    m.ToTable("Fields");
    m.Requires("ValueType").HasValue((int)Service.DataTypes.MemberType.Field).IsRequired();
})
.Map<SECONDTYPE>(m =>
{
    m.Requires("ValueType").HasValue(42);
}); 
于 2013-02-03T12:28:07.907 回答