我有一个程序集,其中包含我的域类 - “Domains.dll”。我动态地添加到我的 DbContext Dbset 加载程序集类。
public class MyContext : DbContext
{
public MyContext() : base("DBConnection"){}
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
Assembly assembly = Assembly.LoadFrom("Domains.dll");
var entityMethod = typeof(DbModelBuilder).GetMethod("Entity");
var list = assembly.GetTypes().OrderBy(i => i.GetType().Name);
foreach (Type item in list)
{
entityMethod.MakeGenericMethod(item)
.Invoke(modelBuilder, new object[] { });
}
}
}
接下来,我创建数据库
context.Database.Create();
这有效,但我的域存在问题。我有一个父实体类
public abstract class Entity
{
[Key]
[DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]
public int Id { get; set; }
}
public class Person : Entity
{
public string FirstName {get ;set;}
public string LastName {get ;set;}
}
如果现在我运行一个数据库 - 未创建表“Person”。它会创建一个包含字段 Id、FirstName、LastName 的表“Entities”。
如果我改变了这个人
public class Person
{
public int Id {get; set;}
public string FirstName {get ;set;}
public string LastName {get ;set;}
}
然后在数据库中创建了两个表 - 'Person' 和 'Entities'。我如何使用继承?我该怎么做才正确?
最佳答案
尝试使用 [Table("Person")]
属性,我鼓励您看一下 Inheritance with EF Code First , 这是一篇好文章。
所以要继续尝试这个:
public abstract class Entity
{
[Key]
[DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]
public int Id { get; set; }
}
[Table("Person")]
public class Person : Entity
{
public string FirstName {get ;set;}
public string LastName {get ;set;}
}
关于c# - Entity Framework (代码优先)——动态构建模型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17879206/