Java使用flyway实现脚本自动化的方法详解

 更新时间:2023年10月27日 09:40:39   作者:生命猿于运动  
Flyway是一个开源的数据库版本控制工具,主要用于管理数据库的版本和变更,它可以自动化地将数据库迁移到不同的版本,同时支持多种数据库类型,本文给大家介绍了如何使用flyway实现脚本自动化,需要的朋友可以参考下

如何使用

使用Flyway,仅需将编写的好SQL语句写成sql脚本文件,根据版本规定填写正确的文件名,存放到指定的目录底下,在项目进行启动时即可自动扫描指定目录底下的脚本,根据数据库Flyway配置表进行对比,将未执行的脚本按顺序自动执行。

Flyway脚本迁移文件命名需要遵循以下规则:

如上图,文件命名规范主要分为以下几个部分:

  • 前缀:V表示版本化迁移,U表示撤销迁移,R表示可重复迁移。
  • 下划线:在版本号中下划线会被.替换。
  • 分隔符:两个下划线,用来分隔版本号与文件描述词
  • 描述:脚本文件内容的简短描述,执行后内容中的下划线则会被替换为空格。

文件名版本号与文件描述内容以两个下划线分隔开,命名示例:

  • V1_20231026154401__create_student_table.sql
  • V1_20231026162233__insert_student_data.sql

通常情况下我们都是直接以V前缀进行命名,在需要进行回退操作时,直接在脚本中写好回退的脚本即可。

更多内容可以参考官方文档说明:https://documentation.red-gate.com/fd/migrations-184127470.html#versioned-migrations

案例分析

首先需要引入flyway依赖包:

<dependency>
	<groupId>org.flywaydb</groupId>
	<artifactId>flyway-core</artifactId>
	<version>6.4.1</version>
</dependency>

application.yml文件中添加flyway相关配置信息,开启flyway脚本迁移功能:

spring:
  flyway:
    # flyway 开启/关闭
    enabled: true
    # 当迁移时发现目标schema非空,而且带有没有元数据的表时,是否自动执行基准迁移,默认false.
    baseline-on-migrate: true
    # 是否允许无序的迁移,默认false.
    out-of-order: true
    # 迁移时是否校验,默认为true
    validate-on-migrate: false
    # 迁移脚本的位置,默认db/migration.
    locations: classpath:db
    # flyway 基线版本号
    baseline-version: 0
    # flyway 执行记录表
    table: demo_flyway_schema_history

在上面的配置中也描述了每个属性参数的作用,上面的脚本位置配置的是locations: classpath:db,在这里我们就可以将需要进行迁移执行的脚本文件,按上面的命名规范配置好之后存放到此目录下:

确认好文件存放位置无误之后,我们就可以直接启动服务:

如图服务启动成功后,我们就可以看到相关flyway执行的日志信息,如果是首次使用flyway迁移脚本的话,那么就会自动帮我们创建一个flyway执行记录表,表结构如下:

  • installed_rank:主键
  • version:版本号
  • description:文件描述
  • type:脚本类型
  • script:完整文件名
  • checksum:flyway通过特定的算法根据文件内容计算出来的一个整数,可以简单理解为文件内容的标识符,如果我们在配置中开启校验时(validate-on-migrate=true),如果我们文件内容有修改将计算出新的checksum与执行过的的checksum不一致时即会报mismatch的错误,以此来告知开发者脚本有变动。
  • installed_by:执行脚本的数据库用户
  • execution_time:执行时间
  • success:执行结果,0:失败,1:成功

总结

有了这么一个脚本迁移的工具,对于开发人员也好,对运维人员也罢,都能够减轻双方的负担,并且减少在部署时手动去执行脚本出错的风险,好的工具一直在为我们节约更多的时间,用上之后真的停不下来。

以上就是Java使用flyway实现脚本自动化的方法详解的详细内容,更多关于Java flyway实现脚本自动化的资料请关注脚本之家其它相关文章!

相关文章

  • java 11新特性HttpClient主要组件及发送请求示例详解

    java 11新特性HttpClient主要组件及发送请求示例详解

    这篇文章主要为大家介绍了java 11新特性HttpClient主要组件及发送请求示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-06-06
  • Spark Streaming编程初级实践详解

    Spark Streaming编程初级实践详解

    这篇文章主要为大家介绍了Spark Streaming编程初级实践详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04
  • Java数据结构之LinkedList从链表到实现

    Java数据结构之LinkedList从链表到实现

    LinkedList是Java中常用的数据结构之一,实现了链表的特性,支持快速添加、删除元素,可以用于实现队列、栈、双向队列等数据结构。LinkedList的内部实现采用了双向链表,其中每个节点都包含前驱节点和后继节点的引用,可以直接访问链表的头尾元素
    2023-04-04
  • 创建SpringBoot工程并集成Mybatis的方法

    创建SpringBoot工程并集成Mybatis的方法

    这篇文章主要介绍了创建SpringBoot工程并集成Mybatis,需要的朋友可以参考下
    2018-06-06
  • java异步写日志到文件中实现代码

    java异步写日志到文件中实现代码

    这篇文章主要介绍了java异步写日志到文件中实现代码的相关资料,需要的朋友可以参考下
    2017-04-04
  • 解决BeanUtils.copyProperties无法成功封装的问题

    解决BeanUtils.copyProperties无法成功封装的问题

    这篇文章主要介绍了解决BeanUtils.copyProperties无法成功封装的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06
  • Java 实战项目锤炼之在线美食网站系统的实现流程

    Java 实战项目锤炼之在线美食网站系统的实现流程

    读万卷书不如行万里路,只学书上的理论是远远不够的,只有在实战中才能获得能力的提升,本篇文章手把手带你用java+SSM+jsp+mysql+maven实现一个在线美食网站系统,大家可以在过程中查缺补漏,提升水平
    2021-11-11
  • JavaEE账号注册模拟网站邮箱激活

    JavaEE账号注册模拟网站邮箱激活

    这篇文章主要为大家详细介绍了JavaEE账号注册模拟网站邮箱激活,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • 如何实现java执行kettle并传参数

    如何实现java执行kettle并传参数

    文章主要介绍了在审批成功后如何使用Kettle传递批次号参数并执行KTR文件,同时,提到了所需的主要POM依赖,并强调了个人经验的价值,鼓励大家参考和使用
    2025-01-01
  • 使用JMX连接JVM实现过程详解

    使用JMX连接JVM实现过程详解

    这篇文章主要介绍了使用JMX连接JVM实现过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-04-04

最新评论