springboot集成flyway

flyway可以自动同步数据库脚本,在一个新环境部署时只需要创建好数据库后自动生成所有脚本中的sql,保证数据库一致性,节省部署时间

  1. 在yml配置文件中添加配置,连接到项目的数据库
    locations: classpath:db/migration是resources中新建一个文件夹,文件名随便命名,里边放一些sql文件,项目启动后会自动扫描未运行的sql文件,可以将我们写好的sql之类的自动生成至数据库中
yaml 复制代码
spring:
  flyway:
    enabled: true
    clean-disabled: true
    baseline-version: 1.0
    baseline-on-migrate: true
    url: jdbc:postgresql://127.0.0.1:5432/hel-sfld
    user: postgres
    password: password
    locations: classpath:db/migration
  1. 需要手动新建文件夹
  2. pom文件中添加对应的依赖,最好加上代码生成依赖
java 复制代码
<!-- Flyway 数据库迁移 -->
        <dependency>
            <groupId>org.flywaydb</groupId>
            <artifactId>flyway-core</artifactId>
            <version>7.15.0</version>
        </dependency>
        <!-- 代码生成的 -->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-generator</artifactId>
            <version>3.5.1</version>
        </dependency>
  1. 创建sql文件,文件名格式: V1.1__init_db.sql
    如果项目数据库已经存在了,那我们直接在数据库工具中导出所有表和数据的sql然后新建sql文件,一般是第一个,名字就是上边那个,把内容粘贴进去,第一次启动后flyway自动扫描完,不会报错,然后后边再新建的就起V1.2 V1.3 ... 里边写新增的sql就行。
相关推荐
JustHappy3 小时前
古法编程秘籍(七):互联网到底是什么?把两台电脑怎么说话搞懂就够了
前端·后端·网络协议
yaoxin5211233 小时前
434. Java 日期时间 API - Period 基于日期的时间段
java·开发语言·python
Hommy883 小时前
【剪映小助手】添加图片接口(Add Images)
后端·github·剪映小助手·视频剪辑自动化
GetcharZp3 小时前
别再盲目用 OpenCV 读图了,这才是 CV 预处理的终极杀手锏!
后端
何极光4 小时前
IDEA集成Maven
java·maven·intellij-idea
程序员二叉4 小时前
【JUC】ThreadLocal底层原理|内存泄漏|弱引用|跨线程传递方案
java·开发语言·面试·职场和发展·juc
程序员二叉4 小时前
【JUC】线程池全套深度详解|参数|流程|拒绝策略|调优|异常处理
java·开发语言·jvm·算法·面试·juc
老马识途2.04 小时前
在AI的帮助下理解spring的启动过程
java·前端·spring
青山木4 小时前
Hot 100 --- 轮转数组
java·数据结构·算法
Qt程序员5 小时前
掌握 Linux 内核调度:从原理到实现(进程篇)
java·开发语言