知识库

Loading

0 评论 / 0 点赞 / 170 阅读  常见问题 最后更新: 2022-09-20 作者: 飞致云 总字数: 1138

1 前言

由于DataEase 引入了 Flyway 框架,产品研发只需要将版本迭代的数据库更改脚本内容写在 VXX_XX.sql 上,并且按照顺序来命名。DataEase 的后端程序就会一直往下执行,并且在 DataEase 的数据库上有 dataease_verison 表,此表会记录下 Flyway 执行在哪一步。执行成功的话会在 success 列上标注 1。所以说,一般报错的状态会是 0。
image-1657765665209
2
image-1657765691031

2 演示出错

2.1 新增脚本文本测试

手动新增 V99_9.9.sql 进行测试使用,主要是留意这条语句。

UPDATE V99Test set class = '班级5' WHERE `` = '4';

这是个语法错误,where 后面没有带字段 ,执行肯定会报错,首先咱们先执行一遍。
image-1657765716987
image-1657765788928

报错的信息刚好就是说语句有问题,这时候重新回到 dataease_verison 表看下,是否有记载我新写的版本号。
image-1657765795505

如最初的结论一样,只要 flyway 的版本语句有一处执行失败就会将 success 的状态设置成 0。然后我们再往数据库找下是否有 v99test 的表。
7

找到了,但是里面没有数据,证明 INSERT 语句并没有执行,或者说 flyway 将这些更改插入操作当做一个事务,只要失败全部就回退。但是创建语句没有回退,导致了数据库就“提前”拥有了这张表。我们将语句补充完整之后,再运行一次 DataEase 后端程序。
image-1657765805257

Flyway 直接报错 Schema dataease-wei contains a failed migration to version 99 ! 这就是大量用户询问后端执行报错的问题。由于用户之前执行了脚本已经出错或者已经更改过某表结构与我们的脚本语句不同导致出错。
image-1657765810918

3 解决问题

3.1 情况一

我们将V99的脚本语句全部复制出来在 navicat 运行下试试看。
image-1657765816575
image-1657765822836

完美的执行所有语句,这时候就代表脚本语句已经全部执行,这跟我们后端代码启动执行运用 flyway 执行的效果是一样的。所以说我们可以直接到 dataease_verison 将 V99 的 success 状态由 0 改成 1 ,最后再执行后端程序解决。
image-1657765827367

3.2 情况二

将脚本语句复制到 navicat 运行之后报错,我们就需要找到是哪一行报错,然后通过去更改脚本语句使之成功运行。例如下图报错说表已经存在,这时候就需要将创建表的语句跳过,直接往下执行脚本。
image-1657765832190
14

脚本已经全部执行成功,然后再 dataease_verison 找到对应的 99 版本的 success 设置 1 即可。
image-1657765840137

3.3 情况三

假如你是自己二次开发修改了某张表的结构,DataEase 新版本恰好更新了这张表的结构。这就会导致研发小哥写的 SQL语句跟你自己二次开发的不一致导致报错,这时候要么你就找到相关语句去修改成符合自己二次开发的结构。要么就直接舍去研发小哥写的内容跳过执行,但是第二种方法是极其不推荐的。

文章目录
其他资源