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

Ras*_*kov 13 c# entity-framework entity-framework-core asp.net-core

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

我创建了初始迁移.

dotnet ef migrations add InitialMigration
Run Code Online (Sandbox Code Playgroud)

资源

当我有一些模型更改时,我创建了新的迁移更新.

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

当然丢弃数据库不是一个选项,我必须保存数据!

Sam*_*ath 21

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

但有一个解决方法.

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

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

PM> Add-Migration InitialCreate
Run Code Online (Sandbox Code Playgroud)

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

第4步:运行:

 PM> Update-Database
Run Code Online (Sandbox Code Playgroud)

它会在__EFMigrationsHistory表格中插入一条新记录.

步骤5:之后,从保存在步骤3的安全位置的内容中填写上述迁移脚本(即.._InitialCreate)Up()Down()方法.

这就对了.现在你只有1个迁移文件:)

注意:带有软件包管理器控制台(PM)的EF核心:软件包管理器控制台

  • 这不是一个好的解决方案。它必须明确指出这是一个坏主意,并且只能在将其应用于生产环境之前谨慎地在测试环境中使用。 (3认同)
  • 代替在步骤3中“同时删除Up()和Down()方法代码”,您只需注释掉`Up()`方法,然后在最后的步骤5中取消注释即可。 (3认同)
  • 这种方法似乎丢失了原始 SQL 语句,例如“Up()”或“Down()”中使用的“migrationBuilder.Sql()” (2认同)

Rom*_*eau 8

当您想要合并最后 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认同)

kiz*_*lsu 5

一种方法是物理删除所有迁移文件并添加新文件。如果您的迁移在“Migrations”文件夹中,您可以简单地将其删除,否则您也需要删除您的“ModelSnapshot”文件。我认为这种方法可以解决您的问题。