SpringBoot整合Liquibase

SpringBoot整合Liquibase虽然不难但坑还是有一点的,主要集中在配置路径相关的地方,在此记录一下整合的步骤,方便以后自己再做整合时少走弯路,当然也希望能帮到大家~

整合有两种情况

  1. 在启动项目时自动执行脚本,若新添加了Liquibase脚本需要重启项目才能执行脚本
  2. 在不启动项目时也能通过插件或指令手动让它执行脚本

整合要么只整合1,要么1、2一起整合

只整合2不整合1的话,项目启动时会生成liquibase相关的bean时报错

整合1

引入Maven依赖

这里导入了Liquibase的包和连接MySQL数据库的包

<!-- https://mvnrepository.com/artifact/org.liquibase/liquibase-core -->
<dependency>
    <groupId>org.liquibase</groupId>
    <artifactId>liquibase-core</artifactId>
    <version>3.6.2</version>
</dependency>
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <scope>runtime</scope>
</dependency>

在SpringBoot配置文件中配置

配置中liquibase相关的只需要配置根changelog的位置,数据库相关配置liquibase会自己去拿datasource下面的,注意url需要加上时区serverTimezone

spring:
  datasource:
    username: root
    password: root
    url: jdbc:mysql://localhost:3306/test_database?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai
  liquibase:
    change-log: classpath:/db/liquibaseChangeLogFile.xml

配置liquibaseChangeLogFile.xml

同样需要注意xml文件的路径,按照上述配置的话该文件在src/main/resources/db/liquibaseChangeLogFile.xml

<?xml version="1.0" encoding
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Spring Boot可以很方便地与Liquibase集成,以实现数据库版本控制和迁移。下面是整合步骤: 1. 添加Liquibase依赖 在pom.xml文件中添加Liquibase依赖: ``` <dependency> <groupId>org.liquibase</groupId> <artifactId>liquibase-core</artifactId> <version>3.8.9</version> </dependency> ``` 2. 配置Liquibase 在application.properties文件中添加Liquibase配置: ``` #Liquibase配置 spring.liquibase.change-log=classpath:/db/changelog/db.changelog-master.xml spring.liquibase.enabled=true spring.liquibase.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=UTC spring.liquibase.user=root spring.liquibase.password=root ``` 其中,change-log属性指定Liquibase的changelog文件路径,url、user和password属性指定数据库连接信息。 3. 创建changelog文件 在resources/db/changelog目录下创建db.changelog-master.xml文件,用于定义数据库版本控制和迁移的变更集合。 例如: ``` <?xml version="1." encoding="UTF-8"?> <databaseChangeLog xmlns="http://www.liquibase.org/xml/ns/dbchangelog" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog http://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-3.8.xsd"> <changeSet id="1" author="liquibase"> <createTable tableName="person"> <column name="id" type="bigint" autoIncrement="true"> <constraints primaryKey="true" nullable="false"/> </column> <column name="name" type="varchar(255)"> <constraints nullable="false"/> </column> <column name="age" type="int"/> </createTable> </changeSet> </databaseChangeLog> ``` 4. 运行应用程序 运行Spring Boot应用程序,Liquibase将自动检测数据库版本并执行相应的变更集。 以上就是Spring Boot整合Liquibase的步骤。 ### 回答2: Spring Boot是一款非常流行的Java框架,它为开发人员提供了一种简单、快速并且有效的方法来开发和部署Web应用程序。而Liquibase是一款专门用于管理数据库变更的工具,它提供了一种简单、可靠的方式来进行数据库的合并、迁移和关系升级等操作。本篇文章将会介绍如何使用Spring Boot和Liquibase进行数据库管理和变更。 1. 配置Liquibase 在pom.xml文件中,引入Liquibase的依赖。 ```xml <dependency> <groupId>org.liquibase</groupId> <artifactId>liquibase-core</artifactId> <version>[版本号]</version> </dependency> ``` 接下来,在application.properties文件中配置Liquibase ```properties spring.liquibase.enabled=true spring.liquibase.change-log=classpath:/db/changelog/db.changelog-master.xml spring.datasource.url=jdbc:mysql://localhost:3306/[数据库名]?useUnicode=true&characterEncoding=UTF8&allowMultiQueries=true&autoReconnect=true&failOverReadOnly=false&maxReconnects=5 spring.datasource.username=[用户名] spring.datasource.password=[密码] spring.datasource.driver-class-name=com.mysql.jdbc.Driver ``` 以上配置可根据实际情况自定义修改。其中,spring.liquibase.enabled=true表示启用Liquibase;spring.liquibase.change-log指定Liquibase的master changelog文件;spring.datasource.*为数据源配置。 2. 编写Liquibase脚本 下面编写一个简单的Liquibase脚本,用于创建一个users表。 ```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" xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog http://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-3.3.xsd"> <changeSet id="create-users-table" author="张三"> <createTable tableName="users"> <column name="id" type="bigserial" autoIncrement="true"> <constraints primaryKey="true"/> </column> <column name="username" type="varchar(50)"/> <column name="password" type="varchar(50)"/> <column name="email" type="varchar(50)"/> </createTable> </changeSet> </databaseChangeLog> ``` 以上脚本使用Liquibase的XML格式编写,用于创建一个名为users的表和其对应的字段。其中,id字段为自增主键,其他字段均为varchar类型。 3. 启动应用 现在,只需运行应用,并等待Liquibase执行创建表的脚本即可。Liquibase会在启动时检查数据库中是否存在对应的表,如果表不存在则会进行创建。如果已存在对应的表,则不会进行任何操作。通过运行时日志,可以看到Liquibase在检查和执行脚本的相关信息。 4. 变更数据库 当需要对数据库进行修改时,只需修改Liquibase脚本即可。Liquibase会自动检测修改并进行相应的变更,无需手动执行SQL语句。当需要更改数据表时,只需编写修改表结构的Liquibase脚本,例如新增一列。 ```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" xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog http://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-3.3.xsd"> <changeSet id="add-email-to-users-table" author="张三"> <addColumn tableName="users"> <column name="email" type="varchar(50)"/> </addColumn> </changeSet> </databaseChangeLog> ``` 运行应用,Liquibase会自动检测到该变更操作,并进行相应的变更。 总结 通过Spring Boot整合Liquibase,我们可以轻松地将数据库管理和版本控制集成到应用中,从而提高开发效率、减少错误和风险。Liquibase提供了丰富的脚本语法和插件支持,为数据库管理带来了更多可能性。 ### 回答3: Spring Boot 是一种开箱即用的微服务框架,可以让开发者快速搭建并部署应用程序,而 Liquibase 是一个开源的数据库版本控制和迁移工具,可以帮助开发者管理数据库的变化与版本迭代。在实际的项目开发中,为了方便在集成开发环境(IDE)中更好地管理数据库的版本变更和迁移,通常需要 Spring Boot 整合 Liquibasespringboot整合liquibase)。 Spring Boot 整合 Liquibase 可以让开发者利用 Liquibase 强大的功能实现持续集成和部署,达到自动化管理数据库变更的效果,同时让开发者更加高效地进行开发。下面我们来了解一下 Spring Boot 整合 Liquibase 的具体实现步骤: ## 1. 引入依赖 在 pom.xml 文件中加入以下依赖: ```xml <dependency> <groupId>org.liquibase</groupId> <artifactId>liquibase-core</artifactId> <version>4.5.0</version> </dependency> ``` ## 2. 编写 Liquibase 配置文件 在 resources 目录下新建 liquibase 目录,并在该目录下新建 liquibase.properties 文件。该文件包含了一些 Liquibase 的配置信息,例如: ```properties changeLogFile=classpath:db/changelog/changelog-master.xml url=jdbc:mysql://localhost:3306/springdemo username=root password=root driver=com.mysql.cj.jdbc.Driver ``` ## 3. 编写 Liquibase changelog 在 resources 目录下新建 db/changelog 目录,并在该目录下新建一个 changelog-master.xml 文件,该文件描述了数据库的变更历史以及变更脚本: ```xml <databaseChangeLog xmlns="http://www.liquibase.org/xml/ns/dbchangelog" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog http://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-4.0.xsd"> <changeSet id="1" author="dbo"> <createTable tableName="person"> <column name="id" type="bigint" autoIncrement="true"> <constraints primaryKey="true" nullable="false"/> </column> <column name="name" type="varchar(255)"> <constraints nullable="false"/> </column> <column name="age" type="int"/> </createTable> </changeSet> </databaseChangeLog> ``` ## 4. 启动 Spring Boot 应用 当我们启动 Spring Boot 应用时,Liquibase 将会自动执行 changelog 中定义的变更脚本。例如,我们在命令行执行 mvn spring-boot:run 启动 Spring Boot,则会执行以下操作: 1. 根据 liquibase.properties 中的配置信息,创建与数据库的连接; 2. 根据 changelog-master.xml 中的定义,检查数据库的变更历史; 3. 根据 changelog-master.xml 中的定义,执行数据库的变更脚本,将其应用到数据库中; 4. 关闭与数据库的连接。 总之,Spring Boot 整合 Liquibase 提供了一个方便易用的数据库管理工具,可以帮助开发者更好地管理数据库变更的历史和版本,提高开发效率并保证数据完整性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值