Flyway 介绍以及与 Spring Boot 集成指南

一、Flyway 简介

Flyway 是一款开源的数据库版本管理工具,通过版本化控制实现数据库结构的自动化升级。其核心特性包括:

  • 支持 SQL 脚本和 Java 迁移代码

  • 提供migrate、clean、validate 等核心命令

  • 自动创建flyway_schema_history 表记录版本变更

使用场景:

比如我们现在有三个环境:开发环境、测试环境、生产环境。

  • 在开发环境建了一张商品表,在开发完毕后,在测试环境和生产环境,我们都需要手动去建同样的商品表

  • 开发时,如果A开发和B开发都对同一数据库进行了修改,那么如何进行数据同步呢?假如多个开发人员都修改了sql脚本,怎么同步到测试环境和生产环境?

二、Spring Boot 集成步骤

1. 添加依赖

pom.xml 中添加 Flyway 核心依赖:

复制代码
<dependency>
    <groupId>org.flywaydb</groupId>
    <artifactId>flyway-core</artifactId>
    <version>7.15.0</version> <!-- 版本根据需求调整 -->
</dependency>
<!-- MySQL 驱动示例 -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.26</version>
</dependency>

2. 配置数据库连接

application.yml 中添加配置,(flyway里面的数据库指的是目标数据库(如测试环境或生产环境的数据库))

复制代码
spring:
  datasource:
    url: jdbc:mysql://localhost:3306/product_db?useSSL=false&serverTimezone=UTC
    username: root
    password: root
    driver-class-name: com.mysql.cj.jdbc.Driver
  flyway:
    # 是否启动flyway
    enabled: false
    # 数据库
    table: flyway_schema_history_check
    # 编码格式 默认UTF-8
    encoding: UTF-8
    # 迁移sql脚本文件存放路径 默认在下面db/migration,可以手动修改
    locations: classpath:db/migration/mysql
    # 迁移sql脚本文件名称前缀,默认V 大写
    sql-migration-prefix: V
    # 迁移sql脚本文件名称分隔符,默认2个下划线__
    sql-migration-separator: __
    # 迁移脚本文件名称后缀
    sql-migration-suffixes: .sql
    # 迁移时是否进行校验,默认true
    validate-on-migrate: true
    # 迁移数据库发现数据库非空且存在没有元数据的表时,自动执行基准迁移,新建schema_version表
    baseline-on-migrate: true
    # 禁止清理表数据
    clean-disabled: true
    # 多数据源时使用的数据库 连接地址
    url: ${spring.datasource.dynamic.datasource.primary.url:}
    # 多数据源时使用的数据库 用户名
    user: ${spring.datasource.dynamic.datasource.primary.username:}
    # 多数据源时使用的数据库 密码
    password: ${spring.datasource.dynamic.datasource.primary.password:}

3. 编写迁移脚本

在迁移脚本的目录下创建 SQL 文件,建议命名:采用 V{版本}__{文件描述}.sql 格式(如 V1_2_0__Add_index.sql)

sql 复制代码
-- V1__Create_product_table.sql
CREATE TABLE product (
    id BIGINT PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(255) NOT NULL,
    price DECIMAL(10,2)
);
​
-- V2__Add_stock_column.sql
ALTER TABLE product ADD COLUMN stock INT DEFAULT 0;

4. 启动项目

项目启动时,flyway会自动执行迁移脚本目录下面的sql文件到指定的数据库信息中,Flyway 还会自动创建一个版本表,用于记录数据库的迁移版本信息。这个表的默认名称是 flyway_schema_history

相关推荐
薛定e的猫咪15 小时前
因果推理研究方向综述笔记
人工智能·笔记·深度学习·算法
AOwhisky15 小时前
虚拟化技术学习笔记
linux·运维·笔记·学习·虚拟化技术
一只机电自动化菜鸟15 小时前
一建机电备考笔记(33) 机电专业技术(起重技术-吊装方案)(含考频+题型)
经验分享·笔记·学习·职场和发展·课程设计
小陈phd17 小时前
多模态大模型学习笔记(四十)——从“看字”到“懂结构”:版面分析与表格解析技术全解
笔记·学习
xuhaoyu_cpp_java17 小时前
SpringMVC学习(二)
java·经验分享·笔记·学习·spring
噜噜噜阿鲁~18 小时前
python学习笔记 | 9.2、模块-安装第三方模块
笔记·python·学习
我胖虎不答应!!19 小时前
Three.js开发思想笔记
javascript·笔记·three.js
程序leo源19 小时前
C语言知识总结
c语言·开发语言·c++·经验分享·笔记·青少年编程·c#
河阿里20 小时前
SpringBoot:项目启动速度深度优化
java·spring boot·后端
阿丰资源20 小时前
基于SpringBoot的企业客户管理系统(附源码)
java·spring boot·后端