ASP NET MVC 3 - 如何首先在代码中重置数据库,包含两个表和 Database.Setinitializer

本文关键字:包含两 数据库 置数据 Setinitializer Database MVC NET 代码 何首先 ASP | 更新日期: 2023-09-27 18:32:42

我的问题在于缺乏MVC的经验。基本上,我在数据库中有两个表-人-提供

对于每一个,我都创建了一个模型、一个控制器和一个模型,所以结构看起来像这样:

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 次,每次只填充一个表。如何重新组织所有表,以便可以一次填充两个或多个表,或者填充整个数据库?

ASP NET MVC 3 - 如何首先在代码中重置数据库,包含两个表和 Database.Setinitializer

首先,您不应该为每个表创建单独的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