Spring Boot2 使用 Flyway 管理数据库版本

一 前言

在日常开发中,我们可能经常遇到这样的问题,由于项目需求的变化,或者前期需求设计不完善,导致在后期需要修改已经设计好的数据库表结构。如果是一个新开发的项目,还处于开发阶段,新增字段还好,但是如果是调整某些字段,是不是有点奔溃呢?是不是会考虑过把需要调整的表删除了重新创建呢?目前对于数据库版本进行管理的工具有一些,主要有两个: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 启动项目,查看数据库验证脚本执行结果

相关推荐
virus59456 小时前
悟空CRM mybatis-3.5.3-mapper.dtd错误解决方案
java·开发语言·mybatis
没差c7 小时前
springboot集成flyway
java·spring boot·后端
时艰.7 小时前
Java 并发编程之 CAS 与 Atomic 原子操作类
java·开发语言
编程彩机7 小时前
互联网大厂Java面试:从Java SE到大数据场景的技术深度解析
java·大数据·spring boot·面试·spark·java se·互联网大厂
笨蛋不要掉眼泪8 小时前
Spring Boot集成LangChain4j:与大模型对话的极速入门
java·人工智能·后端·spring·langchain
Yvonne爱编码8 小时前
JAVA数据结构 DAY3-List接口
java·开发语言·windows·python
像少年啦飞驰点、9 小时前
零基础入门 Spring Boot:从“Hello World”到可上线微服务的完整学习指南
java·spring boot·微服务·编程入门·后端开发
眼眸流转9 小时前
Java代码变更影响分析(一)
java·开发语言
Yvonne爱编码9 小时前
JAVA数据结构 DAY4-ArrayList
java·开发语言·数据结构
阿猿收手吧!9 小时前
【C++】C++原子操作:compare_exchange_weak详解
java·jvm·c++