合并实体框架核心中的迁移

时间:2016-11-22 11:34:38

标签: c# entity-framework asp.net-core entity-framework-core

是否可以将所有迁移文件合并为一个?

我创建了初始迁移。

dotnet ef migrations add InitialMigration

Source

如果我有一些模型更改,我会创建新的迁移更新。

但是现在我有太多的迁移更新文件。 是否可以将所有迁移文件合并为一个?

关闭课程丢弃数据库不是一个选项,我必须保留数据!

3 个答案:

答案 0 :(得分:18)

EF 6.X有一个选项IgnoreChanges。这非常适合您的场景。但遗憾的是,它不是EF核心中的一项功能。

但是有一种解决方法。

步骤1:删除迁移文件夹中的所有迁移脚本。

第2步:在包管理器控制台中:运行

PM> Add-Migration InitialCreate

第3步:删除Up()Down()方法代码。在您执行此操作之前,请将这些方法保存在其他位置,因为我们将在步骤5中再次使用它们。

第4步:运行:

 PM> Update-Database

它会在__EFMigrationsHistory表格中插入新记录。

第5步:之后,从保存在内容中​​的内容中填写上述迁移脚本(即.._InitialCreateUp()Down()方法安全的地方第3步

就是这样。现在您只有1个迁移文件:)

注意:包含管理器控制台(PM)的EF核心:Package Manager Console

答案 1 :(得分:3)

当您要合并的不是N个最后的迁移时,协议是不相同的:

  1. 一遍一遍地还原N次最后迁移,一个,每个迁移都使用以下2条命令:
    • dotnet ef database update NameOfTheLastMigration
    • dotnet ef migrations remove
  2. 应用还原到数据库:
    • dotnet ef database update
  3. 创建“合并”迁移:
    • dotnet ef migrations add NameOfTheMergeMigration

答案 2 :(得分:1)

实现此目的的一种方法是物理删除所有迁移文件并添加新文件。如果您的迁移位于“迁移”文件夹中,则只需删除它,否则您也需要删除“ModelSnapshot”文件。我认为这种方法可以解决您的问题。