c# - ASP NET MVC 3 - 如何首先使用两个表和 Database.Setinitializer 在代码中重置数据库?

标签 c# asp.net-mvc entity-framework

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

对于每个我都创建了一个模型、一个 Controller 和一个模型,因此结构如下所示:

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 模型。

首先,我创建了 Person 模型,它将自身添加到数据库中,没有任何问题。然后我想添加 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);
}

据我了解,我不能这样做,因为我删除数据库两次,每次只填充一个表。我如何重新组织这一切,以便我可以一次填充两个或多个表,或整个数据库?

最佳答案

首先,您不应该为每个表创建单独的DbContext 类。您应该将所有 DbSets 放在同一个 DbContext 中。这样做将大大简化您的工作。

其次,您应该考虑使用迁移。您应该在项目的早期就开始使用它们。

您可以使用包管理控制台进行代码优先迁移。

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

关于c# - ASP NET MVC 3 - 如何首先使用两个表和 Database.Setinitializer 在代码中重置数据库?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27212391/

相关文章:

c# - 验证数据库中的 URL 是否存在

entity-framework - 如何在 Entity Framework 中使用内部联接删除或更新?

c# - 边缘成本不对称时的最近邻居,一些疑问

c# - asp.net MVC 级联下拉列表

asp.net-mvc - SQL Server 存储过程减慢查询速度

c# - 在 ASP.NET MVC 和 WPF MVVM 中重用相同的模型

c# - EF LINQ 翻译 : complex query

c# - 使用 WCF 和自托管的 Windows 身份验证

c# - 如何在 C# 中从 TFS 检索工作项列表?

c# - 字符串不在正则表达式中