С EF Code First CTP 4 я создал простой проект. Этот проект состоит из 2 классов, один унаследован от другого.
Я хочу хранить данные в отдельных таблицах, но по умолчанию EF 4 отображает / хранит эти два объекта в одной таблице.
С помощью .ToTable()
я могу изменить это поведение, но с этим у меня возникает побочный эффект: когда я сохраняю объект Inherited, EF не сохраняет общие значения (например, Id) в базовом классе.
Я уверен, что ухожу, чтобы установить некоторую информацию в отображении, но не знаю, какая.
static void Main(string[] args)
{
Database.SetInitializer<ZooContext>(new RecreateDatabaseIfModelChanges<ZooContext>());
using (ZooContext ctx = new ZooContext())
{
Mammal mam = new Mammal() ;
mam.NumberOfLegs = 4;
ctx.Animals.Add(mam);
// ctx.Mammals.Add(mam) as the same behavior
ctx.SaveChanges();
}
}
public class ZooContext : DbContext
{
public DbSet<Animal> Animals { get; set; }
public DbSet<Mammal> Mammals { get; set; }
protected override void OnModelCreating(System.Data.Entity.ModelConfiguration.ModelBuilder modelBuilder)
{
modelBuilder.Entity<Animal>().HasKey(p => p.Id).
MapHierarchy().
Case<Animal>(a => new { a.Id });
modelBuilder.Entity<Animal>().HasKey(p => p.Id).
MapHierarchy().
Case<Mammal>(a => new { a.Id, a.NumberOfLegs }).ToTable("Mammals");
base.OnModelCreating(modelBuilder);
}
}
public class Animal
{
public virtual int Id { get; set; }
}
public class Mammal : Animal
{
public int NumberOfLegs { get; set; }
}