Flyway 是一个开源数据库版本管理工具,将结构变更变为可版本化、可重复执行、可追溯的代码操作;它不替代写SQL,而是统一管理SQL执行顺序、环境与状态,适用于需自动化补丁管理的场景。
Flyway 是一个开源的数据库版本管理工具,核心作用是把数据库结构变更(比如建表、加字段、改索引)变成可版本化、可重复执行、可追溯的代码操作。它不替代你写 SQL,而是帮你管住这些 SQL 的执行顺序、执行环境和执行状态。
关键判断:如果你还在靠人工维护 init.sql、v20250501_add_user_status.sql 这类文件,并靠文档或记忆决定“哪个库跑过哪条”,那 Flyway 就是你要的自动化补丁管理器。
最常见踩坑点:只加依赖不配扫描路径,导致 migration 文件完全不生效。
pom.xml 中引入 flyway-core,版本建议用 9.22.3 或更高(避免老版本对 MySQL 8.0+ 的 json 类型支持问题)src/main/resources/db/migration/,命名必须符合格式:V1__init_schema.sql、V2__add_created_at_to_orders.sql
flyway.locations 指向该路径(Spring Boot 中可在 application.yml 写:spring.flyway.locations=classpath:db/migration)flyway_schema_history 表,记录每次执行的脚本版本、校验和、时间戳——这个表不能删,否则重放会失败错误不是 Flyway 本身坏了,而是它在严格执行约束。以下几种报错出现频率极高:
Validation fai
led: Migration checksum mismatch:说明某条已执行过的 SQL 被手动修改过。解决方式不是删记录,而是用 flyway repair 命令重算校验和(仅限开发/测试环境)Unable to obtain JdbcConnection:通常因 MySQL JDBC 驱动版本不匹配,比如用 mysql-connector-java:8.0.33 连接 MySQL 5.7 时需显式加 ?serverTimezone=UTC 参数SQL State: 45000 | Error Code: 1835(DDL inside stored routine):某些 DDL(如 ALTER TABLE ... ALGORITHM=INSTANT)在低版本 MySQL 不被允许,得降级为 COPY 或改用 flyway.placeholders 动态替换Flyway 管的是“结构演进”,不是数据搬运或业务逻辑。
Vxxx 迁移里V1__create_table.sql 里的 TINYINT(1) 在 PG 里根本不存在真正难的从来不是加个依赖,而是让所有人写 SQL 时心里装着“这条语句未来要被重放十次”。