EF Code-First继承&主要问题

时间:2011-08-15 16:23:09

标签: .net entity-framework ef-code-first

我正在尝试创建一个在需要时自动添加审计跟踪表的函数。 它有点工作,但唯一的问题是审计表没有得到我指定的主键,它保留在先前指定的ItemId作为主键。

这是因为我在ADepartment中继承了Department,并且已经在第一个EntityTypeConfiguration中指定了一个主键。我想EF很聪明,可以实现,但这不是我想要的。

有没有办法告诉第二个EntityTypeConfiguration它应该停止使用ItemId作为主键并开始使用AuditId?

    public class Item
    {
        public int ItemId { get; set;}
    }

    public class Department : Item
    {
        public string Name { get; set; }           
    }

    public class ADepartment : Department, IAudit
    {        
        public int AuditId { get; set; }        
    }


    EntityTypeConfiguration<Department> cfg = new EntityTypeConfiguration<Department>();
    cfg.HasKey(p => p.ItemId);
    cfg.Map(p => p.MapInheritedProperties());                            
    cfg.ToTable(string.Format("Entity{0}", typeof(Department).Name));
    model.Configurations.Add<Department>(cfg);

    EntityTypeConfiguration<ADepartment> c = new EntityTypeConfiguration<ADepartment>();
    c.HasKey(p => p.AuditId);          
    c.Map(p => p.MapInheritedProperties());
    c.ToTable(string.Format("Audit{0}", typeof(ADepartment).Name));            
    model.Configurations.Add<ADepartment>(c);

1 个答案:

答案 0 :(得分:1)

没有办法做到这一点。继承层次结构中的实体必须共享关键属性。如果您需要不同的审计记录密钥,则需要不同于原始类型的实体类型。使用继承类型进行审计会导致很多问题,所以无论如何都应该这样做。例如:

  • 您的每个查询都必须使用OfType<Department>,否则您也会加载审核记录。
  • Department的关系的懒惰和急切加载将同时加载DepartmentADepartment - 除了使用OfType<Department>