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核心:软件包管理器控制台
当您想要合并最后 N 个迁移而不是所有迁移时,协议是不同的:
dotnet ef database update NameOfTheLastMigrationdotnet ef migrations removedotnet ef database updatedotnet ef migrations add NameOfTheMergeMigration一种方法是物理删除所有迁移文件并添加新文件。如果您的迁移在“Migrations”文件夹中,您可以简单地将其删除,否则您也需要删除您的“ModelSnapshot”文件。我认为这种方法可以解决您的问题。
| 归档时间: |
|
| 查看次数: |
5386 次 |
| 最近记录: |