欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Liquibase結(jié)合SpringBoot使用實(shí)現(xiàn)數(shù)據(jù)庫(kù)管理功能

 更新時(shí)間:2024年12月20日 11:23:24   作者:MogulNemenis  
Liquibase 是一個(gè)強(qiáng)大的數(shù)據(jù)庫(kù)管理工具,它幫助你通過自動(dòng)化管理數(shù)據(jù)庫(kù)的變更、版本控制、和回滾,簡(jiǎn)化了開發(fā)中的數(shù)據(jù)庫(kù)遷移工作,這篇文章主要介紹了Liquibase結(jié)合SpringBoot使用實(shí)現(xiàn)數(shù)據(jù)庫(kù)管理,需要的朋友可以參考下

Liquibase概述

Liquibase 是一個(gè)開源的數(shù)據(jù)庫(kù)變更管理工具,用于跟蹤、版本化、和管理數(shù)據(jù)庫(kù)結(jié)構(gòu)(如表、字段、索引等)的變更。它的目的是使數(shù)據(jù)庫(kù)變更的過程更加透明、可控制、自動(dòng)化,避免開發(fā)團(tuán)隊(duì)在多個(gè)環(huán)境中手動(dòng)執(zhí)行相同的數(shù)據(jù)庫(kù)變更腳本。

Liquibase 支持多種數(shù)據(jù)庫(kù)(MySQL、PostgreSQL、Oracle、SQL Server、H2 等),并能夠通過 XML、YAML、JSON 或 SQL 文件來定義數(shù)據(jù)庫(kù)變更。

主要特點(diǎn)

  • 版本控制:將數(shù)據(jù)庫(kù)變更與代碼同步管理,避免手動(dòng)更改數(shù)據(jù)庫(kù)結(jié)構(gòu)。
  • 自動(dòng)化遷移:在不同環(huán)境(開發(fā)、測(cè)試、生產(chǎn)等)中自動(dòng)應(yīng)用數(shù)據(jù)庫(kù)變更。
  • 可回滾性:Liquibase 提供了回滾機(jī)制,可以回到之前的數(shù)據(jù)庫(kù)版本。
  • 支持多種格式:支持 XML、YAML、JSON 等格式來描述變更。
  • 集成方便:Liquibase 可以集成到 CI/CD 流程中,或者與 Spring Boot 等框架配合使用,輕松管理數(shù)據(jù)庫(kù)版本。

工作機(jī)制

Liquibase 使用一個(gè)名為 changelog 的文件來描述數(shù)據(jù)庫(kù)的所有變更。這個(gè)文件記錄了所有執(zhí)行過的數(shù)據(jù)庫(kù)變更集合(changeSets)。每個(gè) changeSet 都有一個(gè)唯一的 ID 和作者標(biāo)識(shí),用來追蹤該變更。

Liquibase 會(huì)通過 changelog 文件自動(dòng)管理數(shù)據(jù)庫(kù)的版本和變更。它會(huì)在每次應(yīng)用變更時(shí),通過一個(gè) DATABASECHANGELOG 表記錄哪些變更已經(jīng)應(yīng)用過了

與SpringBoot結(jié)合使用

由于我這邊項(xiàng)目上使用的是xml方式,就用xml方式進(jìn)行示例,其余方式的方法,大家感興趣的可以自行前往官網(wǎng)查看文檔。

傳送門:Liquibase Documentation

引入依賴

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>org.example</groupId>
  <artifactId>demo</artifactId>
  <version>1.0-SNAPSHOT</version>
  <packaging>jar</packaging>
  <name>demo</name>
  <url>http://maven.apache.org</url>
  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  </properties>
  <dependencyManagement>
    <dependencies>
      <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-dependencies</artifactId>
        <version>2.7.9</version>  
        <type>pom</type>
        <scope>import</scope>
      </dependency>
    </dependencies>
  </dependencyManagement>
  <dependencies>
    <dependency>
      <groupId>org.liquibase</groupId>
      <artifactId>liquibase-core</artifactId>
      <version>4.21.0</version>
    </dependency>
    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>8.0.29</version> <!-- 或者根據(jù)需要使用適合的版本 -->
    </dependency>
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>
  </dependencies>
  <build>
    <plugins>
      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-compiler-plugin</artifactId>
        <version>3.8.1</version> 
        <configuration>
          <source>17</source> 
          <target>17</target> 
        </configuration>
      </plugin>
    </plugins>
  </build>
</project>

配置文件

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/test?serverTimezone=UTC&useSSL=false
    username: root
    password: 123456
    driver-class-name: com.mysql.cj.jdbc.Driver
    hikari:
      maximum-pool-size: 10
  liquibase:
    change-log: classpath:liquibase/platform/changeSet.xml
    enabled: true

創(chuàng)建 Liquibase 變更集文件

<?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.1.xsd">
    <include file="liquibase/platform/change/change01.xml"/>
</databaseChangeLog>

具體的變更集文件

<?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.1.xsd">
    <changeSet id="1" author="bob">
        <createTable tableName="department">
            <column name="id" type="int">
                <constraints primaryKey="true" nullable="false"/>
            </column>
            <column name="name" type="varchar(50)">
                <constraints nullable="false"/>
            </column>
            <column name="active" type="boolean" defaultValueBoolean="true"/>
        </createTable>
    </changeSet>
</databaseChangeLog>

常用命令

liquibase update: 應(yīng)用所有未執(zhí)行的數(shù)據(jù)庫(kù)變更。
liquibase rollback: 回滾數(shù)據(jù)庫(kù)到指定的 changeSet 或版本。
liquibase status: 查看當(dāng)前數(shù)據(jù)庫(kù)的變更狀態(tài)。
liquibase generateChangeLog: 根據(jù)現(xiàn)有數(shù)據(jù)庫(kù)生成初始的 changeLog 文件。

總結(jié)

Liquibase 是一個(gè)強(qiáng)大的數(shù)據(jù)庫(kù)管理工具,它幫助你通過自動(dòng)化管理數(shù)據(jù)庫(kù)的變更、版本控制、和回滾,簡(jiǎn)化了開發(fā)中的數(shù)據(jù)庫(kù)遷移工作。通過在 Spring Boot 中集成 Liquibase,可以更高效地管理數(shù)據(jù)庫(kù)結(jié)構(gòu)和版本,確保開發(fā)團(tuán)隊(duì)的協(xié)作更加流暢。在項(xiàng)目中,Liquibase 可以和 Git 等版本控制工具配合使用,確保數(shù)據(jù)庫(kù)結(jié)構(gòu)變更的透明性和可追溯性。

到此這篇關(guān)于Liquibase結(jié)合SpringBoot使用實(shí)現(xiàn)數(shù)據(jù)庫(kù)管理的文章就介紹到這了,更多相關(guān)SpringBoot數(shù)據(jù)庫(kù)管理內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解SpringBoot可執(zhí)行Jar包運(yùn)行原理

    詳解SpringBoot可執(zhí)行Jar包運(yùn)行原理

    SpringBoot有一個(gè)很方便的功能就是可以將應(yīng)用打成可執(zhí)行的Jar,那么大家有沒想過這個(gè)Jar是怎么運(yùn)行起來的呢,本篇博客就來介紹下 SpringBoot可執(zhí)行Jar包的運(yùn)行原理,需要的朋友可以參考下
    2023-05-05
  • Java實(shí)現(xiàn)插入公式到PPT的示例代碼

    Java實(shí)現(xiàn)插入公式到PPT的示例代碼

    PPT中可插入公式,用于放映時(shí)演示相關(guān)內(nèi)容的論證、推算的依據(jù)。通過代碼,我們可借助特定的工具來實(shí)現(xiàn)在PPT中的插入公式,本文將對(duì)此作詳細(xì)介紹
    2022-07-07
  • Spring異常實(shí)現(xiàn)統(tǒng)一處理的方法

    Spring異常實(shí)現(xiàn)統(tǒng)一處理的方法

    這篇文章主要介紹了Spring異常實(shí)現(xiàn)統(tǒng)一處理的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-12-12
  • IDEA Ultimate2020.2版本配置Tomcat詳細(xì)教程

    IDEA Ultimate2020.2版本配置Tomcat詳細(xì)教程

    這篇文章主要介紹了IDEA Ultimate2020.2版本配置Tomcat教程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-09-09
  • Java自定義類數(shù)組報(bào)null的相關(guān)問題及解決

    Java自定義類數(shù)組報(bào)null的相關(guān)問題及解決

    這篇文章主要介紹了Java自定義類數(shù)組報(bào)null的相關(guān)問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • 詳解JAVA設(shè)計(jì)模式之代理模式

    詳解JAVA設(shè)計(jì)模式之代理模式

    這篇文章主要介紹了JAVA設(shè)計(jì)模式之代理模式的的相關(guān)資料,文中代碼非常詳細(xì),幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-06-06
  • java微信開發(fā)API第一步 服務(wù)器接入

    java微信開發(fā)API第一步 服務(wù)器接入

    這篇文章主要為大家分享了java微信開發(fā)API的第一步操作服務(wù)器接入,感興趣的小伙伴們可以參考一下
    2016-05-05
  • Java實(shí)現(xiàn)ArrayList自動(dòng)擴(kuò)容

    Java實(shí)現(xiàn)ArrayList自動(dòng)擴(kuò)容

    ArrayList的擴(kuò)容規(guī)則是非常簡(jiǎn)單的,它會(huì)根據(jù)需要自動(dòng)擴(kuò)容,本文就來介紹一下Java實(shí)現(xiàn)ArrayList自動(dòng)擴(kuò)容,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-12-12
  • 使用Mybatis時(shí)SqlSessionFactory對(duì)象總是報(bào)空指針

    使用Mybatis時(shí)SqlSessionFactory對(duì)象總是報(bào)空指針

    本文主要介紹了使用Mybatis時(shí)SqlSessionFactory對(duì)象總是報(bào)空指針,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-09-09
  • maven如何動(dòng)態(tài)統(tǒng)一修改版本號(hào)的方法步驟

    maven如何動(dòng)態(tài)統(tǒng)一修改版本號(hào)的方法步驟

    這篇文章主要介紹了maven如何動(dòng)態(tài)統(tǒng)一修改版本號(hào)的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12

最新評(píng)論