Spring Boot 集成 Flyway 数据库版本管理
Spring Boot Flyway About 1,792 words添加依赖
Spring Boot2.6.7
父工程中默认使用的Flyway
版本为8.0.5
。
需要用到jdbc
依赖(当然配置了MyBatis
等,可以正常加载datasource
的依赖都可以)
<dependency>
<groupId>org.flywaydb</groupId>
<artifactId>flyway-core</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
SQL 脚本存放路径
默认是在classth:db/migration
(可通过spring.flyway.locations
配置修改)
resources
目录下新建db
文件夹,db
文件夹下新建migration
文件夹。
└─src
└─main
├─java
│ └─com
│ └─example
│ └─flyway
│ FlywayApplication.java
│
└─resources
│ application.yml
│
└─db
└─migration
SQL 脚本命令规则
规则:V<VERSION>__<NAME>.sql
示例:
V0.1__INIT_TABLE.sql
V1_0_0__INIT_TABLE.sql
注意:
V
字母要大写。<VERSION>
后面的下划线是两个下划线。- 已经运行过后的
SQL
脚本不应该再被修改,不然启动程序的时候会报错。
可能错误
没有以__
双下划线分割,Flyway
验证失败,不加载脚本。
o.f.core.internal.command.DbValidate : Validating migrations ...
o.f.core.internal.scanner.Scanner : Filtering out resource: db/migration/V0.1_INIT_TABLE.sql (filename: V0.1_INIT_TABLE.sql)
o.f.core.internal.command.DbValidate : Successfully validated 0 migrations (execution time 00:00.031s)
o.f.core.internal.command.DbValidate : No migrations found. Are your locations set up correctly?
手动修改了已经执行过的脚本,导致校验文件码失败。
Caused by: org.flywaydb.core.api.exception.FlywayValidateException: Validate failed: Migrations have failed validation
Migration checksum mismatch for migration version 0.1
-> Applied to database : -73817940
-> Resolved locally : -1919657487. Either revert the changes to the migration, or run repair to update the schema history.
官网
Views: 1,385 · Posted: 2022-10-05
————        END        ————
Give me a Star, Thanks:)
https://github.com/fendoudebb/LiteNote扫描下方二维码关注公众号和小程序↓↓↓
Loading...