我的问题在于缺乏MVC经验。基本上,我在DB -Person -Offer中有两个表
我为每个模型创建了一个模型,一个控制器和一个模型,因此结构如下所示:
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);
}
据我了解,我不能仅仅因为我两次删除数据库,而一次只填充一个表,所以不能做到这一点。如何重新组织所有内容,以便一次可以填充两个或多个表,也可以填充整个数据库?
首先,您不应该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在ASP.NET MVC应用程序中使用实体框架
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句