温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

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

发布时间:2020-02-14 11:09:20 阅读:5163 作者:wx5b3c0a4298f7b 栏目:MySQL数据库
亿速云云数据库,读写分离,安全稳定,弹性扩容,低至0.3元/天!! 点击查看>>

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

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

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

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

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

migrate没有运行增加的SQL脚本

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

亿速云「云数据库 MySQL」免部署即开即用,比自行安装部署数据库高出1倍以上的性能,双节点冗余防止单节点故障,数据自动定期备份随时恢复。点击查看>>

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI

开发者交流群×