使用 Liquibase 管理数据库版本 - SpringBoot 2.7 .2 实战基础

本文介绍了如何在SpringBoot 2.7.2项目中使用Liquibase进行数据库版本管理。通过Liquibase的Maven插件生成changelog文件,详细讲解了从配置到实际应用的步骤,包括配置Maven插件、逆向生成changelog、在SpringBoot中添加依赖和changelog、changeSet的使用以及常见问题的解决方法。
摘要由CSDN通过智能技术生成

优雅哥 SpringBoot 2.7 .2 实战基础 - 05 -使用 Liquibase 管理数据库版本

在企业开发中,数据库版本管理好像是一个伪命题,大多项目都是通过 Power Designer 之类的工具建模、生成 SQL 语句,然后去数据库中执行。在开发过程中如果遇到修改表结构,再补充修改表结构的语句,大家依次去执行,在本地及各个环境中同步表结构。但这种模式,在我参与过的项目中或多或少都出现过问题:忘记同步表结构,导致在服务启动或运行时出错。

1 Liquibase 介绍

SpringBoot 官方文档中推荐了两款工具来管理数据库版本:FlywayLiquibase。前者我没有在项目中使用过,所以本文就只讨论 Liquibase。

使用 Liquibase 需要定义一堆 XML 文件,这些 XML 称为 changelog 文件。每个 changelog 文件中又包含多个变化集合 changeSet,每个 changeSet 记录了作者、改变的内容。changeSet 中要修改的内容,通过 createTableaddColumn 等标签进行操作。通过这种 XML 文件的方式,就可以将代码版本与数据库版本关联在一起。项目启动,会自动执行 changelog XML 文件。Liquibase 具有执行锁,已经执行过的内容不会重复执行。在执行 changeSet 时,由于改动的内容可以通过 Liquibase 提供的标签编写,所以无关具体的数据库产品(MySQL、Oracle 等),Liquibase 底层会根据实际使用的数据库类型转化为对应的 SQL。

通过上面的描述,可以看出 Liquibase 带来的几个好处:

  1. 支持多类型的数据库产品,无需维护 SQL 脚本;
  2. 项目启动可以自动升级数据库;
  3. 代码版本与数据库版本关联在一起。

2 在老项目中使用 Liquibase

在咱们的 demo hero-springboot-demo 中,之前已经手动通过 SQL 语句创建了数据库表 computer,现在想通过 Liquibase 来管理数据库版本和维护表结构,该怎么办呢?本节就通过这个案例来说明已存在的老项目中如何引用 Liquibase。

2.1 配置 Maven 插件

Liquibase 提供了 Maven 插件,使用该插件可以根据数据库逆向生成 changlog 文件。在 pom.xml 的 plugins 下添加 Liquibase 插件:

<plugin>
    <groupId>org.liquibase</groupId>
    <artifactId>liquibase-maven-plugin</artifactId>
    <version>4.9.1</version>
    <configuration>
        <propertyFileWillOverride>true</propertyFileWillOverride>
        <outputChangeLogFile>temp/temp-changelog.xml</outputChangeLogFile>
        <driver>com.mysql.cj.jdbc.Driver</driver>
        <url>jdbc:mysql://127.0.0.1:3306/hero_springboot_demo?useUnicode=true&amp;characterEncoding=utf8&amp;useSSL=true</url>
        <username>root</username>
        <password>Mysql.123</password>
        <outputFileEncoding>UTF-8</outputFileEncoding>
        <verbose>true</verbose>
        <diffTypes>tables, views, columns, indexs,foreignkeys, primarykeys, uniqueconstraints, data</diffTypes>
    </configuration>
</plugin>

上面配置 Liquibase 的 Maven 插件:数据库连接信息和Liquibase生成规则配置。生成的文件路径为 temp 目录下的 temp-changelog.xml,Liquibase 不会自动生成文件夹,需要手动在项目根目录下创建

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员优雅哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值