如何应用代码部分迁移?



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

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

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

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

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

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

dotnet ef database update Migration_Name

将数据库更新到特定迁移。

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

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

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

最新更新