iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >java中如何使用Flyway管理数据库的版本变更
  • 387
分享到

java中如何使用Flyway管理数据库的版本变更

2023-06-16 18:06:47 387人浏览 安东尼
摘要

这篇文章给大家分享的是有关java中如何使用Flyway管理数据库的版本变更的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1. 前言随着项目的不断迭代,数据库表结构、数据都在发生着变化。甚至有的业务在多环境版本并

这篇文章给大家分享的是有关java中如何使用Flyway管理数据库的版本变更的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

1. 前言

随着项目的不断迭代,数据库表结构、数据都在发生着变化。甚至有的业务在多环境版本并行运行。数据为王的时代,管理好数据库的版本也成为了迫切的需要。如何能做到像 git 之类的版本控制工具来管理数据库?Java 项目中常用 Flyway 和 Liquibase 来管理数据库版本。其中 Flyway 相对来说比较受欢迎。

2. Flyway 的特点

Flyway 大受欢迎是因为它具有以下优点:

  •  简单 非常容易安装和学习,同时迁移的方式也很容易被开发者接受。

  •  专一 Flyway 专注于搞数据库迁移、版本控制而并没有其它副作用。

  •  强大 专为连续交付而设计。让Flyway在应用程序启动时迁移数据库。

3. Flyway 的工作机制

Flyway 需要在 DB 中先创建一个 metadata 表 (缺省表名为 flyway_schema_history), 在该表中保存着每次 migration (迁移)的记录, 记录包含 migration 脚本的版本号和 sql 脚本的 checksum 值。下图表示了多个数据库版本。

java中如何使用Flyway管理数据库的版本变更

对应的 metadata 表记录:

installed_rankversiondescriptiontypescriptchecksuminstalled_byinstalled_onexecution_timesuccess
11Initial SetupSQLV1__Initial_Setup.sql1996767037axel2016-02-04 22:23:00.0546true
22First ChangesSQLV2__First_Changes.sql1279644856axel2016-02-06 09:18:00.0127true

Flyway 扫描文件系统或应用程序的类路径读取 DDL 和 DML 以进行迁移。根据metadata 表进行检查迁移。如果脚本声明的版本号小于或等于标记为当前版本的版本号之一,将忽略它们。其余迁移是待处理迁移:可用,但未应用。最后按版本号对它们进行排序并按顺序执行 并将执行结果写入 metadata 表。

java中如何使用Flyway管理数据库的版本变更

对应的 metadata 表记录:

installed_rankversiondescriptiontypescriptchecksuminstalled_byinstalled_onexecution_timesuccess
11Initial SetupSQLV1__Initial_Setup.sql1996767037axel2016-02-04 22:23:00.0546true
22First ChangesSQLV2__First_Changes.sql1279644856axel2016-02-06 09:18:00.0127true

Flyway 支持命令行(需要下载命令行工具)和 Java api ,也支持构建工具 Maven 和 Gradle 。这里我们将目光放在 Java Api 上。

3. Flyway 的规则

Flyway 是如何比较两个 SQL 文件的先后顺序呢?它采用 采用左对齐原则, 缺位用 0 代替 。举几个例子:

0.1.1 比 1.0.1 版本高。

0.10 比 1.0.9.4 版本高。

0.10 和 1.0.010 版本号一样高, 每个版本号部分的前导 0 会被忽略。

Flyway 将 SQL 文件分为 Versioned 、Repeatable 和 Undo 三种:

  •  Versioned 用于版本升级, 每个版本有唯一的版本号并只能执行一次.

  •  Repeatable 可重复执行, 当 Flyway检测到 Repeatable 类型的 SQL 脚本的 checksum 有变动, Flyway 就会重新应用该脚本. 它并不用于版本更新, 这类的 migration 总是在 Versioned 执行之后才被执行。

  •  Undo 用于撤销具有相同版本的版本化迁移带来的影响。但是该回滚过于粗暴,过于机械化,一般不推荐使用。一般建议使用 Versioned 模式来解决。

这三种的命名规则如下图:

java中如何使用Flyway管理数据库的版本变更

  •  Prefix 可配置,前缀标识,默认值 V 表示 Versioned, R 表示 Repeatable, U 表示 Undo

  •  Version 标识版本号, 由一个或多个数字构成, 数字之间的分隔符可用点 . 或下划线 _

  •  Separator 可配置, 用于分隔版本标识与描述信息, 默认为两个下划线 __

  •  Description 描述信息, 文字之间可以用下划线 _ 或空格 分隔

  •  Suffix 可配置, 后续标识, 默认为 .sql

4. Spring Boot 集成 Flyway

Spring Boot 提供了对 Flyway 的自动配置 。使我们可以开箱即用 Flyway 进行数据库版本控制。

4.1 Flyway 依赖

你只需要引入依赖:   

<!-- 无需版本号 -->   <dependency>        <groupId>org.flywaydb</groupId>        <artifactId>flyway-core</artifactId>   </dependency>

当然你要集成你的相关数据库环境。这里我们采用 H2 数据库来演示,其它数据库同理只不过方言不同。不熟悉 H2 数据库的可参阅我的专题文章 spring Boot 2 实战:H2数据库集成以及使用 。

4.2 Flyway 配置

为了直观的讲解配置,首先在 Spring Boot 配置文件 application.yml 我们配置 H2 数据库为:

spring:     datasource:       #  h3 驱动       driver-class-name: org.h3.Driver       # h3  数据库 持久化到磁盘D:/h3 库名: flyway  mysql模式       url: jdbc:h3:file:D:/h3/flyway;MODE=Mysql;DATABASE_TO_LOWER=TRUE     h3:       #    开启console 访问 默认false       console:         enabled: true         settings:           #      开启h3 console 跟踪 方便调试  默认 false           trace: true           #      允许console 远程访问 默认false           WEB-allow-others: true         #  h3 访问路径上下文         path: /h3-console

对应Flyway的配置为:

# flyway 配置  spring:    flyway:      # 启用或禁用 flyway      enabled: true      # flyway 的 clean 命令会删除指定 schema 下的所有 table, 生产务必禁掉。这个默认值是 false 理论上作为默认配置是不科学的。      clean-disabled: true      # SQL 脚本的目录,多个路径使用逗号分隔 默认值 classpath:db/migration      locations: classpath:db/migration      #  metadata 版本控制信息表 默认 flyway_schema_history      table: flyway_schema_history      # 如果没有 flyway_schema_history 这个 metadata 表, 在执行 flyway migrate 命令之前, 必须先执行 flyway baseline 命令      # 设置为 true 后 flyway 将在需要 baseline 的时候, 自动执行一次 baseline。      baseline-on-migrate: true      # 指定 baseline 的版本号,默认值为 1, 低于该版本号的 SQL 文件, migrate 时会被忽略      baseline-version: 1      # 字符编码 默认 UTF-8      encoding: UTF-8      # 是否允许不按顺序迁移 开发建议 true  生产建议 false      out-of-order: false      # 需要 flyway 管控的 schema list,这里我们配置为flyway  缺省的话, 使用spring.datasource.url 配置的那个 schema,      # 可以指定多个schema, 但仅会在第一个schema下建立 metadata 表, 也仅在第一个schema应用migration sql 脚本.      # 但flyway Clean 命令会依次在这些schema下都执行一遍. 所以 确保生产 spring.flyway.clean-disabled 为 true      schemas: flyway      # 执行迁移时是否自动调用验证   当你的 版本不符合逻辑 比如 你先执行了 DML 而没有 对应的DDL 会抛出异常      validate-on-migrate: true

请务必仔细阅读 Flyway 相关配置的说明。

4.3 编写 SQL 初始化脚本

我们先编写一个初始化 SQL 文件,向 H2 数据库已经自动初始化的 schema flyway 添加一张 sys_user 表。请注意命名规则。脚本名称为 V1.0.1__Add_table_user.sql 。SQL 脚本的位置在配置的 spring.flyway.locations 下。内容为:

use `flyway`;  CREATE TABLE `sys_user`  (      `user_id`         int(10) unsigned NOT NULL AUTO_INCREMENT,      `username`        varchar(1024)    NOT NULL unique ,      `encode_passWord` varchar(1024)       NOT NULL,      `age`             int(3)           NOT NULL,      PRIMARY KEY (`user_id`)  ) ENGINE = InnoDB    DEFAULT CHARSET = utf8mb4;  insert into  flyway.sys_user values (1,'Felordcn','{noop}12345',18);

启动 Spring Boot 应用 。打开 H2 数据库控制台 Http://localhost:8080/h3-console ,在 JDBC URL 一栏粘贴 jdbc:h3:file:D:/h3/flyway;MODE=mysql;DATABASE_TO_LOWER=TRUE 并点击 Connect 按钮会进入以下界面:

java中如何使用Flyway管理数据库的版本变更

这里 -1 是因为我们缺省了 Flyway 需要的 flyway_schema_history 表 。0 是因为 H2 数据库自动初始化了 Schema flyway ,其它数据库可能需要你手动来建立。

4.4 编写 SQL 变更脚本

我们编写一个 V1.0.0__Delete_sysuser_felordcn.sql 来删除 V1.0.1__Add_table_user.sql 中初始化的用户。你会发现启动报错了,因为我们开启了校验,所以对于逻辑错误的版本会抛出异常。我们将版本号更改为 V1.0.2__Delete_sysuser_felordcn.sql 再次启动。通过 H2 数据库控制台我们会发现多了一条变更记录:

java中如何使用Flyway管理数据库的版本变更

同时 sys_user 表的数据也没有了,符合预期。

5. Flyway 最佳实践

通过上面的介绍相信你很快就会使用 Flyway 进行数据库版本控制了。这里总结了一些在实际开发中的使用经验:

  1.  生产务必禁 spring.flyway.cleanDisabled=false 。

  2.  尽量避免使用 Undo 模式。

  3.  开发版本号尽量根据团队来进行多层次的命名避免混乱。比如 V1.0.1__ProjectName_{Feature|fix}_Developer_Description.sql ,这种命名同时也可以获取更多脚本的开发者和相关功能的信息。

  4.  spring.flyway.outOfOrder 取值 生产上使用 true,开发中使用 false。

  5.  多个系统公用一个 数据库 schema 时配置spring.flyway.table 为不同的系统设置不同的 metadata 表名而不使用缺省值 flyway_schema_history 。

感谢各位的阅读!关于“java中如何使用Flyway管理数据库的版本变更”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

--结束END--

本文标题: java中如何使用Flyway管理数据库的版本变更

本文链接: https://www.lsjlt.com/news/284756.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • java中如何使用Flyway管理数据库的版本变更
    这篇文章给大家分享的是有关java中如何使用Flyway管理数据库的版本变更的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1. 前言随着项目的不断迭代,数据库表结构、数据都在发生着变化。甚至有的业务在多环境版本并...
    99+
    2023-06-16
  • 详解Spring Boot中使用Flyway来管理数据库版本
    如果没有读过上面内容的读者,有兴趣的可以一阅。在上面的使用JdbcTemplate一文中,主要通过spring提供的JdbcTemplate实现对用户表的增删改查操作。在实现这个例子的时候,我们事先在MySQL中创建了用户表。创建表的过程我...
    99+
    2023-05-30
  • 如何在SQLite中管理数据库版本
    在SQLite中管理数据库版本的一种常见方法是使用版本号(version number)来跟踪数据库的变化。当数据库发生结构上的变化...
    99+
    2024-03-14
    SQLite
  • SpringBoot使用Flyway进行数据库管理的操作方法
    目录一、Flyway简介二、SpringBoot集成使用1.pom.xml引入依赖2.application.properties3.resources创建db数据库脚本文件夹4.启...
    99+
    2024-04-02
  • 如何使用数据库迁移神器Flyway
    本篇内容介绍了“如何使用数据库迁移神器Flyway”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!数据迁移前...
    99+
    2024-04-02
  • PHP与数据库变更管理的集成
    随着Web应用程序规模和复杂性的增加,数据库变更管理成为Web开发中不可忽视的一项任务。数据库变更管理是数据库开发的核心任务之一,它指的是对数据库的结构进行更改,并确保更改不会影响应用程序的正常运行。在Web应用程序开发中,PHP与数据库变...
    99+
    2023-05-15
    数据库 PHP 变更管理
  • Git的使用技巧:如何更好地管理版本?
    Git是一个非常流行的版本管理工具,它可以让开发者更好地管理代码版本。在这篇文章中,我们将会介绍一些Git的使用技巧,帮助你更好地管理版本。 使用分支 Git支持分支,这是一个非常有用的特性。通过使用分支,你可以在不影响主线代码的情况下...
    99+
    2023-10-15
    编程算法 javascript git
  • 如何使用NPM来管理Java的版本依赖?
    在Java的开发过程中,我们经常需要使用到各种各样的库和框架,这些依赖的版本管理是非常重要的一项工作。在Node.js的生态中,我们通常会使用NPM来管理依赖,那么,我们是否也可以使用NPM来管理Java的版本依赖呢?本文将会介绍如何使用...
    99+
    2023-09-23
    索引 npm leetcode
  • java如何更改数据库中的数据
    java更改数据库中的数据 不废话,上代码 package com.ningmeng; import java.sql.*; public class Test04 { ...
    99+
    2024-04-02
  • Java如何使用Maven BOM统一管理版本号
    这篇文章将为大家详细讲解有关Java如何使用Maven BOM统一管理版本号,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Java是什么Java是一门面向对象编程语言,可以编写桌面应用程序、Web应用程序...
    99+
    2023-06-14
  • 数据库管理工具heidiSQL的基本使用
    安装完成以后;连接进入;看一下有4个默认的mysql数据库;除了test,其他三个是mysql的系统数据库,不要操作; test数据库目前是空的;新建一个表,在数据库节点右击,创建新的->表; 在出现的界面,先输入表名,也可以输入注...
    99+
    2023-10-09
    数据库 sqlserver mysql heidisql
  • win10 1909版本中如何更改管理员名称
    本篇内容介绍了“win10 1909版本中如何更改管理员名称”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!调出运行窗口,输入control命...
    99+
    2023-06-27
  • Java中如何使用数据库
    在Java中使用数据库,需要进行以下步骤:1. 导入数据库驱动:首先需要导入相应的数据库驱动,以便在Java程序中与数据库进行交互。...
    99+
    2023-08-14
    Java 数据库
  • Java Git:揭秘版本控制的奥秘,轻松管理代码变更
    Git 是什么? Git 是一个分布式版本控制系统,这意味着每个开发人员的计算机上都有一个完整的代码库副本。这与集中式版本控制系统(如 Subversion)不同,其中只有一个中央代码库副本。分布式版本控制系统的一个主要优点是它使开发人...
    99+
    2024-02-07
    Git 版本控制 代码管理 协作 开源
  • 如何使用 PHP 函数更新数据库中的数据?
    您可以使用 php 函数更新数据库中的数据:1. 建立数据库连接;2. 准备 sql 查询;3. 执行 sql 查询;4. 检查受影响的行数;5. 关闭数据库连接。 如何在 PHP 中...
    99+
    2024-04-30
    php 更新数据库 mysql
  • 如何使用nvm管理多版本node
    这篇文章将为大家详细讲解有关如何使用nvm管理多版本node,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。首先,使用下面的命令来安装 nvm$ curl&nbs...
    99+
    2024-04-02
  • 在AmazonAurora中如何管理数据库实例的生命周期和版本升级
    在Amazon Aurora中,可以通过使用Amazon RDS控制台或AWS CLI来管理数据库实例的生命周期和版本升级。 创建...
    99+
    2024-04-09
    AmazonAurora
  • 如何回溯 PHP 函数的版本变更历史?
    php 函数的版本变更历史可以通过使用 datetime 函数回溯:安装 php pharcomposer克隆 php 源代码仓库创建 phar 存档运行 phar对于 datetime...
    99+
    2024-04-25
    php 版本变更历史 git composer
  • 在Eclipse中如何使用版本管理工具SVN
    这篇文章主要为大家展示了“在Eclipse中如何使用版本管理工具SVN”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“在Eclipse中如何使用版本管理工具SVN”这篇文章吧。1.SVN安装由于这...
    99+
    2023-05-30
    eclipse svn
  • mac中如何使用NVM管理不同node版本
    这篇文章给大家分享的是有关mac中如何使用NVM管理不同node版本的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Mac 下通过 brew install nvm 所安装的 nv...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作