Flyway是一个数据库版本化管理工具,经过SQL脚本实现DB Migration自动化升级,支持独立运行,也能够和构建工具或者Spring开发环境集成。
sql
总结在实际开发过程当中常见错误,分享解决方法和建议:数据库
l migrate运行失败,提示sql脚本错误ide
解决:独立运行flyway命令repair修复数据库中的升级信息,纠正SQL错误后再次migrate工具
建议:运行migrate以前,首先确保SQL正确。spa
l migrate没有运行增长的SQL脚本开发
解决:SQL脚本命名遵照规则,好比V1.0.0__init.sqlit
l migrate运行失败,提示权限不够,“xxx command denied to user ‘xxx’”自动化
解决:帐号须要拥有对应sql脚本须要的权限,好比create tableio
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开始,使用三位数字。