我的问题在于缺乏MVC的经验。基本上,我在DB中有两个表 -人 - 提供
对于每个我创建了一个模型,一个控制器和一个模型,所以结构看起来像这样:
public class Offer
{
public int OfferID { get; set; }
public string OfferTitle { get; set; }
public string State { get; set; }
public string Description { get; set; }
}
public class OfferDBContext : DbContext
{
public DbSet<Offer> Offers { get; set; }
}
这是优惠模式。
public class Person
{
public int PersonID { get; set; }
public string Username { get; set; }
public DateTime Birthday { get; set; }
public string Education { get; set; }
public string Email { get; set; }
}
public class PersonDBContext : DbContext
{
public DbSet<Person> Persons { get; set; }
}
这是人物模型。
首先我创建了Person模型,它将自己添加到db而没有任何问题。然后我想添加Offer表,我不得不使用DropCreateDatabaseIfModelChanges方法。我将它用于OfferInitializer和PersonInitializer,然后是Global.asax.cs文件
protected void Application_Start()
{
Database.SetInitializer<OfferDBContext>(new OfferInitializer());
Database.SetInitializer<PersonDBContext>(new PersonInitializer());
//Database.SetInitializer<PersonDBContext>(new PersonInitializer());
AreaRegistration.RegisterAllAreas();
RegisterGlobalFilters(GlobalFilters.Filters);
RegisterRoutes(RouteTable.Routes);
}
根据我的理解,我不能这样做只是因为我丢弃数据库2次,每次只填充一个表。我如何重新组织它,以便我可以一次填充两个或多个表,或整个数据库?
答案 0 :(得分:2)
首先,您不应为每个表创建单独的DbContext
类。您应该将所有DbSets
放在同一个DbContext
中。这样做会大大简化你的工作。
其次,您应该考虑使用migrations
。您应该在项目的早期开始使用它们。
使用程序包管理控制台进行代码优先迁移。
enable-migrations
顾名思义究竟是什么意思。初始化项目中的迁移。这将在项目中创建一个文件夹并生成所需的文件。
add-migration InitialCreate
这会创建一个迁移。 InitialCreate实际上是一个字符串,您可以将其更改为您想要的任何内容。此命令将生成从strach创建数据库所需的脚本。
update-database
此命令验证数据库并应用迁移(或迁移 - 可能有多个)以使数据库保持最新。
这是初始设置。如果您对第一个代码的第一个类进行进一步更改,或者添加更多,则只需添加一个新的迁移,然后执行它。
add-migration AddedFirstName
update-database
就这么简单!
还有一些更高级的概念,如种子,回滚,特定迁移更新等,但我上面输入的内容涵盖了迁移的基础知识和日常使用。
我建议你阅读这篇文章,它更详细地解释了所有内容:http://www.asp.net/mvc/overview/getting-started/getting-started-with-ef-using-mvc/migrations-and-deployment-with-the-entity-framework-in-an-asp-net-mvc-application