一 前言
在日常开发中,我们可能经常遇到这样的问题,由于项目需求的变化,或者前期需求设计不完善,导致在后期需要修改已经设计好的数据库表结构。如果是一个新开发的项目,还处于开发阶段,新增字段还好,但是如果是调整某些字段,是不是有点奔溃呢?是不是会考虑过把需要调整的表删除了重新创建呢?目前对于数据库版本进行管理的工具有一些,主要有两个:Flyway、Liquibase。对于 Liquibase 本文不做过多介绍,本文主要介绍一下 Flyway。
二 在 SpringBoo2 中使用 Flyway
2.1 添加依赖
bash
<dependency>
<groupId>org.flywaydb</groupId>
<artifactId>flyway-core</artifactId>
</dependency>
2.2 添加配置
bash
spring
# flyway配置
flyway:
enabled: true
baseline-on-migrate: true # 自动基线已有库
validate-on-migrate: true # 检查脚本是否被篡改
clean-disabled: true # 禁止 clean(保护数据)
locations: classpath:db/migration # 脚本目录
encoding: UTF-8
sql-migration-prefix: V # 默认就是 V
2.3 创建db/migration目录
在项目或者模块下的 resources 目录下,手动创建 db/migration 目录。

2.4 创建脚本
在db/migration 目录下创建数据库脚本文件,脚本文件的命名方式如下:
bash
V<VERSION>__<NAME>.sql
注意:首先是大写字母 V,然后是版本号,要是有小版本可以用下划线隔开,例如 3_1,版本号后面是两个下划线,然后是脚本名称,文件后缀是sql。

2.5 启动项目,查看数据库验证脚本执行结果

