flyway版本号_Flyway版本化管理数据库常见错误和解决方法

Flyway是一个数据库版本化管理工具,通过SQL脚本实现DB Migration自动化升级,支持独立运行,也可以和构建工具或者Spring开发环境集成。

总结在实际开发过程中常见错误,分享解决方法和建议:

l migrate运行失败,提示sql脚本错误

解决:独立运行flyway命令repair修复数据库中的升级信息,纠正SQL错误后再次migrate

建议:运行migrate之前,首先确保SQL正确。

l migrate没有运行增加的SQL脚本

解决:SQL脚本命名遵守规则,比如V1.0.0__init.sql

l migrate运行失败,提示权限不够,“xxx command denied to user ‘xxx’”

解决:账号需要拥有对应sql脚本需要的权限,比如create table

l migrate运行失败,提示数据库不空,“Found non-empty schema(s)”

解决:按照提示独立运行flyway命令baseline初始化。

建议:清空数据库,初始化从空数据库开始。

l 提示找不到数据库,“unkown database ‘xxx’”

解决:需要先创建出来一个空数据库。

l Spring集成Flyway后,清空数据,启动失败

解决:确认validationQuery,是否select 1 from dual还是某个指定的数据表。空数据库时需使用dual

l Spring集成Flyway后,启动运行出错

解决:某些依赖数据库的bean,需要指定在Flyway完成migrate之后运行

l SQL脚本V1.0__xxx.sql没有被运行

解决:Flyway通过版本号码唯一区分脚本,如果最开始运行baseline,Flyway将自动创建版本1.0

建议:1,从空数据库开始初始化,不要运行baseline

建议:2,初始化SQL脚本版本号从V1.0.1开始,使用三位数字。

标签:脚本,migrate,数据库,Flyway,版本,SQL,运行

来源: https://blog.51cto.com/13851865/2468567

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值