我正在尝试创建一个在需要时自动添加审计跟踪表的函数。 它有点工作,但唯一的问题是审计表没有得到我指定的主键,它保留在先前指定的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);
答案 0 :(得分:1)
没有办法做到这一点。继承层次结构中的实体必须共享关键属性。如果您需要不同的审计记录密钥,则需要不同于原始类型的实体类型。使用继承类型进行审计会导致很多问题,所以无论如何都应该这样做。例如:
OfType<Department>
,否则您也会加载审核记录。Department
的关系的懒惰和急切加载将同时加载Department
和ADepartment
- 除了使用OfType<Department>