我正在尝试使用flyway修复方法从具有spring boot配置的模式版本化表中删除不成功的迁移条目。我的代码如下;
@Bean
public FlywayMigrationStrategy repairStrategy() {
return flyway -> {
flyway.repair();
flyway.migrate();
};
}但是运行后会抛出这样的错误(即使迁移操作被注释掉,修复操作也会失败);
Error while retrieving the list of applied migrations from Schema History table
SQL State : 72000
Error Code : 12838
Message : ORA-12838: cannot read/modify an object after modifying it in parallel你有什么想法吗?这里有没有并行操作?顺便说一句,我使用的是Oracle ATP数据库和flyway社区版。
发布于 2020-02-03 22:20:54
Flyway修复不会为您修复数据库(see docs here)。它所做的是将模式历史表修复回有效状态。修复数据库留给用户(因为这不是一项微不足道的任务)。
在这种情况下,您可以尝试提交commit;。这应该允许您运行修复,然后再次迁移。请参阅:https://dbaclass.com/article/ora-12838-cannot-readmodify-object-modifying-parallel/
https://stackoverflow.com/questions/59666601
复制相似问题