如何从代码应用部分迁移?

ast*_*ker 6 c# entity-framework-core entity-framework-migrations

假设我总共有 3 个迁移:A、B 和 C。所有迁移都内置于代码中并从代码中执行(我的意思是 C#)。

我想将所有迁移应用到给定级别(例如 B),让我重新控制,这样我就可以在 EF/migrations/etc 范围之外做任何我喜欢的事情。当我完成我自己的东西时,然后执行完全迁移(所以在这种情况下它意味着 C)。

我知道如何从代码执行完全迁移 :-),但是如何告诉 EF 迁移到给定级别?

从代码 (C#) 执行所有内容在这里至关重要——SQL 脚本或运行外部工具对我来说是行不通的。

对于好奇的头脑:用例——我想为中间的最后一次迁移准备测试。

Mal*_*lum 6

根据 EF-Core 文档,您应该能够运行:

dotnet ef database update Migration_Name

将数据库更新到某个迁移。

从代码运行有点不同。您可以context.Database.Migrate()用来应用所有待处理的迁移。查看此方法的源代码,我们可以看到它使用了底层IMigrate服务。我想你可以尝试这样的事情:

_context.Database.GetService<IMigrator>().Migrate("Migration_Name");

这应该与我之前提到的 cli 命令相同。我目前没有快速的方法来测试这个,所以它可能不起作用。