SpringBoot第37讲:SpringBoot数据库管理 - 用Liquibase对数据库管理和迁移

news2025/1/16 7:59:25

SpringBoot第37讲:SpringBoot数据库管理 - 用Liquibase对数据库管理和迁移

Liquibase是一个用于跟踪、管理和应用数据库变化的开源工具,通过日志文件(changelog)的形式记录数据库的变更(changeset),然后执行日志文件中的修改,将数据库更新或回滚(rollback)到一致的状态。它的目标是提供一种数据库类型无关的解决方案,通过执行schema类型的文件来达到迁移。本文是SpringBoot第37讲,主要介绍 SpringBoot 与 Liquibase的集成

文章目录

  • SpringBoot第37讲:SpringBoot数据库管理 - 用Liquibase对数据库管理和迁移
    • 1、知识准备
      • 1.1、什么是Liquibase?这类工具要解决什么问题?
      • 1.2、Liquibase有哪些概念?是如何工作的?
    • 2、简单示例
      • 2.1、POM依赖
      • 2.2、yml配置
      • 2.3、新增changelog
      • 2.4、测试
    • 3、进一步理解
      • 3.1、比较好的changelog的实践?
      • 3.2、除了addColumn, addTable还有哪些changeType呢?
    • 4、示例源码

1、知识准备

需要理解什么是Liquibase,它的出现是要解决什么问题。

1.1、什么是Liquibase?这类工具要解决什么问题?

Liquibase是一个用于用于跟踪、管理和应用数据库变化的开源工具,通过日志文件(changelog)的形式记录数据库的变更(changeset),然后执行日志文件中的修改,将数据库更新或回滚(rollback)到一致的状态。它的目标是提供一种数据库类型无关的解决方案,通过执行schema类型的文件来达到迁移。

其优点主要有以下

  • 支持几乎所有主流的数据库,目前支持包括 Oracle/Sql Server/DB2/MySql/Sybase/PostgreSQL等 各种数据库,这样在数据库的部署和升级环节可帮助应用系统支持多数据库;
  • 支持版本控制,这样就能支持多开发者的协作维护;
  • 日志文件支持多种格式,如XML, YAML, JSON, SQL等;
  • 提供变化应用的回滚功能,可按时间、数量或标签(tag)回滚已应用的变化。通过这种方式,开发人员可轻易的还原数据库在任何时间点的状态
  • 支持多种运行方式,如命令行、Spring集成、Maven插件、Gradle插件等。

为何会出现Liquibase这类工具呢

在实际上线的应用中,随着版本的迭代,经常会遇到需要变更数据库表和字段,必然会遇到需要对这些变更进行记录和管理,以及回滚等等;同时只有脚本化且版本可管理,才能在让数据库实现真正的DevOps(自动化执行 + 回滚等)。在这样的场景下Liquibase等工具的出现也就成为了必然。

1.2、Liquibase有哪些概念?是如何工作的?

工作流程:将SQL变更记录到changeset,多个changeset变更组成了日志文件(changelog),liquibase将changelog更新日志文件同步到指定的RDBMS中。

img

日志文件(databaseChangeLog)支持多种格式,如XML, YAML, JSON, SQL; 我们以xml为例,看下相关配置

<?xml version="1.0" encoding="UTF-8"?>
<databaseChangeLog
	xmlns="http://www.liquibase.org/xml/ns/dbchangelog"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xmlns:ext="http://www.liquibase.org/xml/ns/dbchangelog-ext"
	xmlns:pro="http://www.liquibase.org/xml/ns/pro"
	xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog
		http://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-4.9.0.xsd
		http://www.liquibase.org/xml/ns/dbchangelog-ext http://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-ext.xsd
		http://www.liquibase.org/xml/ns/pro http://www.liquibase.org/xml/ns/pro/liquibase-pro-4.9.0.xsd">
    <changeSet id="1" author="bob">
        <comment>A sample change log</comment>
        <createTable/>
    </changeSet>
    <changeSet id="2" author="bob" runAlways="true">
        <alterTable/>
    </changeSet>
    <changeSet id="3" author="alice" failOnError="false" dbms="oracle">
        <alterTable/>
    </changeSet>
    <changeSet id="4" author="alice" failOnError="false" dbms="!oracle">
        <alterTable/>
    </changeSet>
</databaseChangeLog>

2、简单示例

这里主要介绍基于 SpringBoot 集成 liquibase 来管理数据库的变更。

2.1、POM依赖

Maven 包的依赖,主要包含mysql驱动, JDBC(这里spring-boot-starter-data-jpa包含了jdbc包,当然直接引入jdbc包也行),以及liquibase包。

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.28</version>
</dependency>
<dependency>
    <groupId>com.github.wenhao</groupId>
    <artifactId>jpa-spec</artifactId>
    <version>3.1.0</version>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>

<dependency>
    <groupId>org.liquibase</groupId>
    <artifactId>liquibase-core</artifactId>
    <version>4.9.1</version>
</dependency>

2.2、yml配置

SpringBoot AutoConfig默认已经包含了对liquibase的配置,在spring.liquibase配置下。

基础的配置,可以直接使用如下(主要是指定change-log的位置,默认的位置是classpath:/db/changelog/db.changelog-master.yaml):

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/db_user_liquibase?useSSL=false&autoReconnect=true&characterEncoding=utf8
    driver-class-name: com.mysql.cj.jdbc.Driver
    username: root
    password: qwj930828
  liquibase:
    enabled: true
    # 如下配置是被spring.datasource赋值的,所以可以不配置
#    url: jdbc:mysql://localhost:3306/db_user_liquibase?useSSL=false&autoReconnect=true&characterEncoding=utf8
#    user: root
#    password: qwj930828
    change-log: classpath:/db/changelog/db.changelog-master.yaml

在开发时,更多的配置可以从如下SpringBoot AutoConfig中找到。

在这里插入图片描述

2.3、新增changelog

XML方式固然OK,不过依然推荐使用yml格式。

databaseChangeLog:
  - changeSet:
      id: 20220412-01
      author: qiwenjie
      changes:
        - createTable:
            tableName: person
            columns:
              - column:
                  name: id
                  type: int
                  autoIncrement: true
                  constraints:
                    primaryKey: true
                    nullable: false
              - column:
                  name: firstname
                  type: varchar(50)
              - column:
                  name: lastname
                  type: varchar(50)
                  constraints:
                    nullable: false
              - column:
                  name: state
                  type: char(2)

  - changeSet:
      id: 20220412-02
      author: qiwenjie
      changes:
        - addColumn:
            tableName: person
            columns:
              - column:
                  name: username
                  type: varchar(8)

  - changeSet:
      id: 20220412-03
      author: qiwenjie
      changes:
        - addLookupTable:
            existingTableName: person
            existingColumnName: state
            newTableName: state
            newColumnName: id
            newColumnDataType: char(2)

2.4、测试

启动springBootApplication, 我们可以看到如下的几个changeSet被依次执行

2023-08-13 15:23:34.075  INFO 73868 --- [           main] liquibase.lockservice                    : Successfully acquired change log lock
2023-08-13 15:23:34.288  INFO 73868 --- [           main] liquibase.changelog                      : Creating database history table with name: db_user_liquibase.DATABASECHANGELOG
2023-08-13 15:23:34.320  INFO 73868 --- [           main] liquibase.changelog                      : Reading from db_user_liquibase.DATABASECHANGELOG
Running Changeset: classpath:/db/changelog/db.changelog-master.yaml::20220412-01::qiwenjie
2023-08-13 15:23:34.548  INFO 73868 --- [           main] liquibase.changelog                      : Table person created
2023-08-13 15:23:34.549  INFO 73868 --- [           main] liquibase.changelog                      : ChangeSet classpath:/db/changelog/db.changelog-master.yaml::20220412-01::qiwenjie ran successfully in 24ms
Running Changeset: classpath:/db/changelog/db.changelog-master.yaml::20220412-02::qiwenjie
2023-08-13 15:23:34.572  INFO 73868 --- [           main] liquibase.changelog                      : Columns username(varchar(8)) added to person
2023-08-13 15:23:34.572  INFO 73868 --- [           main] liquibase.changelog                      : ChangeSet classpath:/db/changelog/db.changelog-master.yaml::20220412-02::qiwenjie ran successfully in 18ms
Running Changeset: classpath:/db/changelog/db.changelog-master.yaml::20220412-03::qiwenjie
2023-08-13 15:23:34.651  INFO 73868 --- [           main] liquibase.changelog                      : Lookup table added for person.state
2023-08-13 15:23:34.652  INFO 73868 --- [           main] liquibase.changelog                      : ChangeSet classpath:/db/changelog/db.changelog-master.yaml::20220412-03::qiwenjie ran successfully in 77ms
Running Changeset: classpath:/db/changelog/db.changelog-master.yaml::20220412-04::qiwenjie
2023-08-13 15:23:34.681  INFO 73868 --- [           main] liquibase.changelog                      : SQL in file classpath:/db/changelog/db.changelog-20220412-04.sql executed
2023-08-13 15:23:34.681  INFO 73868 --- [           main] liquibase.changelog                      : ChangeSet classpath:/db/changelog/db.changelog-master.yaml::20220412-04::qiwenjie ran successfully in 26ms
2023-08-13 15:23:34.685  INFO 73868 --- [           main] liquibase.lockservice                    : Successfully released change log lock

查看数据库,你会发现数据已经变更

在这里插入图片描述

那我们如果重新启动这个SpringBootApplication,会怎么呢?

很显然,因为databasechangelog表中已经有相关执行记录了,所以将不再执行变更

2023-08-13 16:53:56.248  INFO 77591 --- [           main] liquibase.lockservice                    : Successfully acquired change log lock
2023-08-13 16:53:56.575  INFO 77591 --- [           main] liquibase.changelog                      : Reading from db_user_liquibase.DATABASECHANGELOG
2023-08-13 16:53:56.642  INFO 77591 --- [           main] liquibase.lockservice                    : Successfully released change log lock

3、进一步理解

通过几个问题,进一步理解。

3.1、比较好的changelog的实践?

简单而言:yml格式 + sql-file方式

执行sqlFile格式的changeSet,如下

在这里插入图片描述

执行的日志如下

2023-08-13 15:23:34.075  INFO 73868 --- [           main] liquibase.lockservice                    : Successfully acquired change log lock
2023-08-13 15:23:34.320  INFO 73868 --- [           main] liquibase.changelog                      : Reading from db_user_liquibase.DATABASECHANGELOG
Running Changeset: classpath:/db/changelog/db.changelog-master.yaml::20220412-01::qiwenjie
2023-08-13 15:23:34.681  INFO 73868 --- [           main] liquibase.changelog                      : SQL in file classpath:/db/changelog/db.changelog-20220412-04.sql executed
2023-08-13 15:23:34.681  INFO 73868 --- [           main] liquibase.changelog                      : ChangeSet classpath:/db/changelog/db.changelog-master.yaml::20220412-04::qiwenjie ran successfully in 26ms
2023-08-13 15:23:34.685  INFO 73868 --- [           main] liquibase.lockservice                    : Successfully released change log lock

执行后,查看变更记录

在这里插入图片描述

数据表user表已经创建并插入一条数据

在这里插入图片描述

3.2、除了addColumn, addTable还有哪些changeType呢?

除了addColumn,addTable还有哪些changeType呢?

与此同时,还支持如下changeType:

img

此外,还支持执行command

changeSet:  
  id:  executeCommand-example
  author:  liquibase-docs
  changes:
  -  executeCommand:
      args:
      -  arg:
          value:  -out
      -  arg:
          value:  -param2
      executable:  mysqldump
      os:  Windows 7
      timeout: 10s

比如,回滚的操作可以通过如下command进行

img

再比如,我们可以通过Liquibase来生成相关差异,再制作成changeSet,最后部署。

4、示例源码

todo

参考文章

https://docs.liquibase.com

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/885247.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

JavaScript进阶 第三天

编程思想构造函数原型 一.编程思想 面向过程&#xff1a;分析出解决问题所需要的步骤&#xff0c;然后利用函数把这些步骤一步一步实现&#xff0c;使用的时候再一个一个依次调用就可以了&#xff08;按照步骤划分&#xff09;面向对象&#xff1a;把事务分解成一个个对象&…

网络通信原理IP头部格式(第四十二课)

字段作用解析:1)版本: 指的IP地址的版本 (IPv4 或 IPV6)2)首部长度: 次数据包的首部长度一共是多少,没有加可选项3)优先级与服务类型:表示****数据包是否需要优选传递4)总长度: 表示的是整个数据包的大小,也就****是首部+数据5)标识符、标志、段偏移量:的作用将拆开的…

Java基础篇--重写(Override)与重载(Overload)

目录 重写&#xff08;Override&#xff09; 重写&#xff08;override&#xff09;的规则&#xff1a; 重载&#xff08;Overload&#xff09; 重载&#xff08;overload&#xff09;的规则&#xff1a; 示例代码 重写与重载之间的区别 总结 在Java中&#xff0c;重写…

Unity C# 之 Azure 微软SSML语音合成TTS流式获取音频数据以及表情嘴型 Animation 的简单整理

Unity C# 之 Azure 微软SSML语音合成TTS流式获取音频数据以及表情嘴型 Animation 的简单整理 目录 Unity C# 之 Azure 微软SSML语音合成TTS流式获取音频数据以及表情嘴型 Animation 的简单整理 一、简单介绍 二、实现原理 三、注意事项 四、实现步骤 五、关键代码 一、简…

港科夜闻|香港科大(广州)与南沙科金控股签订战略合作协议,为南沙创新生态与高质量发展提供持续强劲动力...

关注并星标 每周阅读港科夜闻 建立新视野 开启新思维 1、香港科大(广州)与南沙科金控股签订战略合作协议&#xff0c;为南沙创新生态与高质量发展提供持续强劲动力。双方将以此为契机&#xff0c;立足自身资源优势&#xff0c;完善合作机制&#xff0c;深化合作领域&#xff0c…

MOM or MES:如何选择适合工厂的制造管理系统?

在现代制造业中&#xff0c;有效的制造管理系统对于工厂的生产效率和竞争力至关重要。这衍生出来了两个常见的解决方案&#xff1a;MOM&#xff08;Manufacturing Operations Management&#xff09;制造管理系统和MES&#xff08;Manufacturing Execution System&#xff09;制…

无涯教程-Perl - socketpair函数

描述 此函数使用PROTOCOL在指定的DOMAIN(指定的TYPE)中创建一对未命名的连接Socket。如果未实现系统socketpair()函数,则将导致致命错误。 语法 以下是此函数的简单语法- socketpair SOCKET1, SOCKET2, DOMAIN, TYPE, PROTOCOL返回值 如果失败,此函数返回0,如果成功,则返回…

基于STM32CUBEMX驱动TMOS模块STHS34PF80(5)----配置嵌入式函数

基于STM32CUBEMX驱动TMOS模块STHS34PF80----4.中断获取信号 概述样品申请视频教程参考Demo参考Demo内嵌函数地址串口配置IIC配置IO口设置串口重定向参考程序初始化IIC写函数IIC读函数获取ID设备的自动引导过程和关机模式配置省电模式温度数据的灵敏度值设置低通滤波器温度测量滤…

Java算法_ 反转二叉树(LeetCode_Hot100)

题目描述&#xff1a;给你一棵二叉树的根节点 &#xff0c;翻转这棵二叉树&#xff0c;并返回其根节点。root。 获得更多&#xff1f;算法思路:代码文档&#xff0c;算法解析的私得。 运行效果 完整代码 /*** 2 * Author: LJJ* 3 * Date: 2023/8/16 13:18* 4*/public class In…

无涯教程-Perl - split函数

描述 此函数根据PATTERN指定的分隔符将字符串表达式拆分为多个字段。如果未指定任何模式,则默认为空白。可选限制限制了返回的元素数。 负限制与无限制具有相同的作用。此函数通常与join()结合使用以创建小型文本数据库。 语法 以下是此函数的简单语法- split /PATTERN/, …

每天一道leetcode:1218. 最长定差子序列(动态规划中等)

今日份题目&#xff1a; 给你一个整数数组 arr 和一个整数 difference&#xff0c;请你找出并返回 arr 中最长等差子序列的长度&#xff0c;该子序列中相邻元素之间的差等于 difference 。 子序列 是指在不改变其余元素顺序的情况下&#xff0c;通过删除一些元素或不删除任何…

mavros源码安装与配置

0 背景 Ubuntu20.04 双系统 ROS Noetic Mavros本质上是ROS的一个功能包&#xff0c;因为笔者需要对其进行二次开发&#xff0c;所以选择源码安装。 参考&#xff1a;官方repository链接&#xff0c;官方安装文档 1 安装步骤 首先&#xff0c;确保安装了catkin相关工具 # f…

防御DDoS服务应如何选择?一文全面讲透

最近人人都在谈论 DDoS&#xff0c; DDoS攻击不仅会损害受害者的金钱、服务和信誉&#xff0c;伴随着互联网的快速发展&#xff0c;它的防御难度相当大。报告显示&#xff0c;65%以上的DDoS攻击每小时给受害企业造成的损失高达一万美金。那么如何为企业构建全面的应对策略&…

Java:PO、VO、BO、DO、DAO、DTO、POJO

&#x1f497;wei_shuo的个人主页 &#x1f4ab;wei_shuo的学习社区 &#x1f310;Hello World &#xff01; Java&#xff1a;PO、VO、BO、DO、DAO、DTO、POJO PO持久化对象&#xff08;Persistent Object&#xff09; PO是持久化对象&#xff0c;用于表示数据库中的实体或表…

Iridient Developer for mac RAW图像调整

Iridient Developer 支持多种不同的文件格式&#xff0c;包括常见的RAW格式&#xff0c;如CR2、NEF、RAF等&#xff0c;以及JPEG、TIFF等。它具有非常精确的图像处理引擎&#xff0c;能够提供高质量的图像细节和色彩还原。 该软件提供了丰富的调整选项&#xff0c;包括曝光、白…

GRPC 链接 NODE 和 GOLANG

GRPC 链接 NODE 和 GOLANG GRPC 了解 什么是GRPC gRPC 采用了 Protocol Buffers 作为数据序列化和反序列化的协议&#xff0c;可以更快速地传输数据&#xff0c;并支持多种编程语言的跨平台使用gRPC 提供“统一水平层”来对此类问题进行抽象化。 开发人员在本机平台中编写专…

idea git命令使用

这个标签标识单签分支&#xff1a;&#xff08;标签图标&#xff09; 标识关联分支&#xff1a;&#xff08;五角星&#xff09; 本地切换分支&#xff1a;如当前分支是dev ,git branch 显示的是dev ,然后通过 git checkout -b release 切换到release分支 git checkout re…

JUC并发集合

目录 传统类集框架的弊端 1.并发集合的类型 2.并发单值集合 3.并发多值集合 4.跳表集合 传统类集框架的弊端 传统的类集框架存在一个非常严重的弊端。那就是在多线程的情况下对集合修改会报错。 如下代码 package Example2123;import java.util.ArrayList; import jav…

easyx图形库基础4:贪吃蛇

贪吃蛇 一实现贪吃蛇&#xff1a;1.绘制网格&#xff1a;1.绘制蛇&#xff1a;3.控制蛇的默认移动向右&#xff1a;4.控制蛇的移动方向&#xff1a;5.生成食物6.判断蛇吃到食物并且长大。7.判断游戏结束&#xff1a;8.重置函数&#xff1a; 二整体代码&#xff1a; 一实现贪吃蛇…

今年七夕情人节,要送数码产品给对象?这几款送人不出错的数码产品

时间过的还挺快的又到了今年的七夕情人节了&#xff0c;你是否还在为送什么数码产品给对象而犯愁&#xff1f;做过功课挑选的数码好物肯定会让TA十分惊喜&#xff0c;作为一个数码发烧友&#xff0c;我盘点了几款适合送对象的数码好物&#xff0c;大家可以甄选看看。 第一款&a…