为什么需要Flyway
日常开发常常会遇到一些这样的场景
- 小红开发一个模块在本地数据库增加了两个字段,并且改动了dao层的代码提交到git。这时候小黄拉取了代码Run很可能报错。
- 如果在上线正式环境的时候,忘记在正式数据库执行sql脚本可能造成严重的问题。
- 传统的解决方式是在一个固定的地方添加sql脚本,开发人员相互沟通执行哪个sql脚本
Flyway可以将这一类问题解决,在项目编译期就将改动写入数据库。只要启动成功就没有问题。
Flyway 导入
如果是Gradle,在build.gradle
添加依赖
Maven 在pom.xml
添加依赖
实际使用
使用Spring Boot,Gradle 构建项目,添加依赖。
如果是已经开发一段时间的项目需要开启 baselineOnMigrate 否则抛出异常
在 application.properties 添加配置
当然也可以实现接口
数据库中的schema_version
为存储对比脚本版本的表
sql脚本默认放置在 classpath:db/migration
文件以.sql结尾,命名V字开头,后面数字为版本号 例如 V1__init.sql
实例:
摘自 org.flywaydb.core.Flyway
可以自定义配置,但是建议不要。
注意:sql脚本需要有相应的版本号,例如如果想让 V2__init.sql
执行 需要有V1__init.sql
作为一个基准对比,然后flyway才会执行相应的sql脚本。
一些链接
https://flywaydb.org/documentation/gradle/
https://github.com/spark-jobserver/spark-jobserver/issues/503
链接:https://www.jianshu.com/p/7f7279376349