ast*_*ker 6 c# entity-framework-core entity-framework-migrations
假设我总共有 3 个迁移:A、B 和 C。所有迁移都内置于代码中并从代码中执行(我的意思是 C#)。
我想将所有迁移应用到给定级别(例如 B),让我重新控制,这样我就可以在 EF/migrations/etc 范围之外做任何我喜欢的事情。当我完成我自己的东西时,然后执行完全迁移(所以在这种情况下它意味着 C)。
我知道如何从代码执行完全迁移 :-),但是如何告诉 EF 迁移到给定级别?
从代码 (C#) 执行所有内容在这里至关重要——SQL 脚本或运行外部工具对我来说是行不通的。
对于好奇的头脑:用例——我想为中间的最后一次迁移准备测试。
根据 EF-Core 文档,您应该能够运行:
dotnet ef database update Migration_Name
将数据库更新到某个迁移。
从代码运行有点不同。您可以context.Database.Migrate()用来应用所有待处理的迁移。查看此方法的源代码,我们可以看到它使用了底层IMigrate服务。我想你可以尝试这样的事情:
_context.Database.GetService<IMigrator>().Migrate("Migration_Name");
这应该与我之前提到的 cli 命令相同。我目前没有快速的方法来测试这个,所以它可能不起作用。
| 归档时间: |
|
| 查看次数: |
259 次 |
| 最近记录: |