SpringBoot项目集成Flyway进行数据库版本控制的详细教程

作者:Cug_wangww 时间:2023-11-24 05:20:33 

Flyway是一款开源的数据库版本管理工具,它更倾向于规约优于配置的方式。

第一步:pom.xml添加maven依赖


<!-- https://mvnrepository.com/artifact/org.flywaydb/flyway-core -->
<dependency>
<groupId>org.flywaydb</groupId>
<artifactId>flyway-core</artifactId>
<version>5.0.7</version>
</dependency>

第二步:开启Flyway支持,在application.properties文件添加Flyway配置


# FLYWAY (FlywayProperties)
flyway.baseline-version=1.0.0
flyway.enabled=true
flyway.sql-migration-prefix=V
flyway.sql-migration-suffix=.sql
flyway.baseline-on-migrate=true
flyway.location=db/migration

第三步:在resource目录下创建db/migration目录添加sql脚本

SpringBoot项目集成Flyway进行数据库版本控制的详细教程

验证是否成功:项目启动时,会运行flyway执行sql语句.生成schema_version表,用于记录sql执行情况.

SpringBoot项目集成Flyway进行数据库版本控制的详细教程

当sql文件修改后.比如多个空格,项目启动时,该sql对应的checksum字段与表记录的不一致会报错.

注意事项:

FlywayProperties参数配置详解

flyway.baseline-version   执行基线时用来标记已有Schema的版本。(默认值:1)
flyway.enabled   开启Flyway。 (默认值: true 。 )
flyway.sql-migration-prefix  SQL迁移的文件名前缀。 (默认值: V 。 )
flyway.sql-migration-suffix  SQL迁移的文件名后缀。 (默认值: .sql 。 )
flyway.baseline-on-migrate   在没有元数据表的情况下,针对非空Schema执行迁移时是否自动调用基线。
flyway.location 迁移脚本的位置。 (默认值: db/migration 。 )

sql文件版本号命名的规范

每个公司的规范肯定不一样.开发时,只需要项目内遵循该规范即可,规范的确定并没有对错.提供一种sql文件命名规范仅供大家参考.

SpringBoot项目集成Flyway进行数据库版本控制的详细教程

来源:https://blog.csdn.net/Cug_wangww/article/details/81150417

标签:SpringBoot,Flyway,数据库版本控制
0
投稿

猜你喜欢

  • Android中实现下载和解压zip文件功能代码分享

    2022-05-31 04:47:26
  • Java实现简单QQ聊天工具

    2023-11-25 05:54:52
  • java实现爬取知乎用户基本信息

    2023-11-26 03:45:18
  • C#计算程序执行过程花费时间的方法

    2022-08-07 08:44:53
  • Docker 存储驱动详细介绍

    2023-12-21 03:18:34
  • IDEA连接Mysql数据库的详细图文教程

    2023-10-09 09:51:24
  • 如何使用JCTools实现Java并发程序

    2023-11-21 07:37:39
  • C++找出字符串中出现最多的字符和次数,时间复杂度小于O(n^2)

    2023-06-22 07:32:31
  • Java多线程之条件对象Condition

    2021-09-25 15:15:30
  • Android UI设计系列之ImageView实现ProgressBar旋转效果(1)

    2021-06-07 11:08:21
  • java实现学籍管理系统

    2023-04-03 00:32:19
  • Android获取点击屏幕的位置坐标

    2023-12-14 21:18:31
  • Java使用BigDecimal进行高精度计算的示例代码

    2023-03-25 10:35:43
  • 如何用C#创建用户自定义异常浅析

    2023-06-10 20:06:16
  • springboot集成shiro详细总结

    2022-07-12 14:56:17
  • springboot中使用Feign整合nacos,gateway进行微服务之间的调用方法

    2021-07-12 07:00:28
  • Java下载远程服务器文件到本地(基于http协议和ssh2协议)

    2022-08-29 12:23:18
  • C#操作session的类实例

    2023-07-17 13:57:19
  • Java三大特性之多态详解

    2022-11-07 14:24:40
  • Java的Spring框架中AOP项目的一般配置和部署教程

    2021-07-26 16:49:25
  • asp之家 软件编程 m.aspxhome.com