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

How to apply partial migration from code?

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

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

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

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

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

According to the EF-Core documentation 你应该可以 运行:

dotnet ef database update Migration_Name

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

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

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

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