• Liquibase-数据库脚本版本管理控制


    🚀 优质资源分享 🚀

    学习路线指引(点击解锁) 知识定位 人群定位
    🧡 Python实战微信订餐小程序 🧡 进阶级 本课程是python flask+微信小程序的完美结合,从项目搭建到腾讯云部署上线,打造一个全栈订餐系统。
    💛Python量化交易实战💛 入门级 手把手带你打造一个易扩展、更安全、效率更高的量化交易系统

    1. 简介

    Liquibase是一个用于跟踪、管理和应用数据库变化的开源的数据库重构工具。它将所有数据库的变化(包括结构和数据)都保存在XML文件中,便于版本控制。

    Liquibase使参与应用程序发布过程的任何人都可以轻松地:

    • 不依赖于特定的数据库,Liquibase会自动适配目标数据库进行脚本初始化,目前支持至少30种主流数据库。
    • 提供数据库比较功能,比较结果保存在XML中,基于该XML可以用Liquibase轻松部署或升级数据库。
    • 以XML记录/存储数据库变化,其中以authorid唯一标识一个变化(ChangSet),支持数据库变化的合并,因此支持多开发人员同时工作。
    • 在数据库中保存数据库修改历史(DatabaseChangeHistory),在数据库升级时自动跳过已应用的变化(ChangSet)。
    • 提供变化应用的回滚功能,可按时间、数量或标签(tag)回滚已应用的变化。通过这种方式,开发人员可轻易的还原数据库在任何时间点的状态。
    • 可生成数据库修改文档(HTML格式)
    • 提供数据重构的独立的IDE和Eclipse插件
    • 将所有变化(包括结构和数据)存在XML文件中,便于版本控制的工具
      springboot支持,只需要导入依赖。
      application.yml配置(可选)
      不配置,默认去resource/db/changelog下找db.changelog-mastert.yml文件

    2. Quick Start

    使用步骤

    • step1: 创建一个数据库变更日志(change log)文件。
    • step2: 在变更日志文件内部创建一个变更集(change set)。
    • step3: 通过命令行或构建脚本对数据库进行变更集。
    • step4: 检验数据库中的变更

    面向spring开发😉,通过springboot 整合 liquibase 了解其作用。

    2.1 添加maven依赖

    
        org.springframework.bootgroupId>
        spring-boot-starter-parentartifactId>
        2.3.9.RELEASEversion>
         
    parent>
    
    
        
            org.springframework.bootgroupId>
            spring-boot-starter-webartifactId>
        dependency>
        
        
            org.liquibasegroupId>
            liquibase-coreartifactId>
            4.8.0version>
        dependency>
        
        
            org.springframework.bootgroupId>
            spring-boot-starter-jdbcartifactId>
        dependency>
        
        
            mysqlgroupId>
            mysql-connector-javaartifactId>
        dependency>
    dependencies>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30

    2.2 application.yaml

    spring:
      datasource:
        driver-class-name: com.mysql.cj.jdbc.Driver
        url: jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true
        username: root
        password: 123456
      liquibase:
        # 指定配置文件路径
        change-log: classpath:db/db.changelog-master.xml
        # 覆盖本地 ddl dml
        drop-first: true
        # 是否启用
        enabled: true
        # 记录版本日志表
        database-change-log-table: databasechangelog
        # 记录版本改变lock表
        database-change-log-lock-table: databasechangeloglock
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    2.3 添加 liquibase xml

    db.changelog-master.xml

    liquibase 配置文件入口,主要用来引用其他的changelog.xml,如下配置文件中的include,当然也可以使用includeAll来引用整个目录

    xml version="1.0" encoding="UTF-8"?
    
    • 1
  • 相关阅读:
    JavaScript代码是怎么在浏览器里面运行起来的?
    在vscode中使用Latex:TexLive2023
    【Android】(最新)跑马灯文字水平滚动(79/100)
    Python函数传递参数
    集成学习(随机森林)
    《大数据之路:阿里巴巴大数据实践》-第3篇 数据管理篇 -第13章 计算管理
    Nginx的使用
    每天分享五款工具,让大家工作生活更顺心
    直播系统开发:基于Nginx与Nginx-rtmp-module实现
    Java框架-MyBatis 详细介绍(crud+缓存+联表+缓存+日志...)
  • 原文地址:https://blog.csdn.net/u012804784/article/details/126801543