加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

asp.net-core – 实体框架核心以编程方式应用迁移

发布时间:2020-12-16 03:17:36 所属栏目:asp.Net 来源:网络整理
导读:我有测试和实时数据库.对于测试数据库迁移,我在包管理器控制台中使用Add-Migration …和Update- Database语法.但对于实时数据库,我想在应用程序启动时以编程方式执行此操作. 以下代码对我没有帮助: context.Database.Migrate(); 当我尝试将记录添加到不存在
我有测试和实时数据库.对于测试数据库迁移,我在包管理器控制台中使用Add-Migration …和Update- Database语法.但对于实时数据库,我想在应用程序启动时以编程方式执行此操作.

以下代码对我没有帮助:

context.Database.Migrate();

当我尝试将记录添加到不存在的表时,我有错误无效的对象名称’TempTenants’.这是我的新表.

但我有_EFMigrationsHistory表.而且我的所有迁移都是那些没有应用的迁移.但我没有看到新表.

如果我从测试数据库中手动删除表并尝试重现错误,我将得到相同的结果.

所以,context.Database.Migrate();仅创建包含所有迁移的新数据库(如果它不存在),但不更新(应用迁移)现有数据库.

我能这样做吗?我该如何解决?

解决方法

似乎出了问题.我从__EFMigrationsHistory表中删除了未应用的迁移(记录)(我还需要将一些表名,主键和外键恢复到以前的状态)并再次启动应用程序.

所以,context.Database.Migrate();即使对于现有数据库也应用迁移.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读