当前位置: 首页 > news >正文

liquibase学习和使用

文章目录

  • liquibase学习
    • 介绍
    • 数据库更新日志和数据库更新日志锁定
    • 相关概念
      • changelog
        • changeset的属性
          • precondition
            • sql样例
          • Contexts
            • sql样例
          • Label
            • sql样例
        • 文件格式
          • sql样例
          • 其他格式用的时候在补充
      • 跟踪表
        • DATABASECHANGELOGLOCK (数据库更改日志锁定表)
        • DATABASECHANGELOG (数据库更新日志表)
    • 命令
      • update
        • 执行情况
  • liquibase使用
    • 基于SpringBoot maven集成Liquibase

liquibase学习

介绍

Liquibase 是一种数据库结构更改管理解决方案,能够从开发到生产更快、更安全地修订和发布数据库更改。

数据库更新日志和数据库更新日志锁定

部署更改时,Liquibase 会在数据库中创建两个表:DATABASECHANGELOG 和 DATABASECHANGELOGLOCK。
数据库更改日志表跟踪已部署的更改,以便您有记录。Liquibase 将变更日志文件中的变更集与 DATABASECHANGELOG 跟踪表进行比较,并仅部署新的变更集。

DATABASECHANGELOGLOCK 可防止 Liquibase 的多个实例同时更新数据库。该表在部署期间管理对 DATABASECHANGELOG 表的访问,并确保只有一个 Liquibase 实例正在更新数据库。

相关概念

changelog

Liquibase 使用changelog按顺序列出对数据库所做的所有更改。
changelog单个更改单元称为changeset,changeset是 Liquibase 中变化的基本单位。将所有changeset存储在changelog中
不同的文件格式(sql,yaml,xml,json)对changeset的描述是不一样的,只是sql文件格式学习成本最低
changset是由changelog的文件路径和author属性和id属性唯一确认的

changeset的属性

precondition

precondition是添加到changelog或单个changeset的标记,用于根据数据库的状态控制更新的执行。通过precondition,您可以指定changeset的安全性和标准化要求。如果changeset上的precondition失败,Liquibase 不会部署该changeset。不过也可以设置不同的属性控制错误的处理方式。
该属性可以在changeset执行前进行检查。
sql文件格式的changelog只支持sqlCheck,其他文件格式支持的检查会多一些。

sql样例
--liquibase formatted sql--changeset Liquibase User:1
--precondition-sql-check expectedResult:0 SELECT COUNT(*) FROM primary_table
--comment: /*comments should go after preCondition. If they are located before the precondition, then Liquibase usually gives error.*/
create table primary_table (  id int primary key,name varchar(50) not null,address1 varchar(50),address2 varchar(50),city varchar(30)
)
Contexts

使用该属性可以在进行更新数据库时,根据输入的参数对changeset进行过滤;属性值是不区分大小写的字符串。具体的判断逻辑可以参考该链接

sql样例
--changeset bob:1 contextFilter:test
insert into news (id, title) values (1, 'Liquibase 0.8 Released')
Label

使用该属性可以在进行更新数据库时,根据输入的参数对changeset进行过滤;属性值是不区分大小写的字符串。label和contexts的具体的判断逻辑可以参考该链接

sql样例
--liquibase formatted sql--changeset Liquibase User:1 labels:1.0
create table primary_table (  id int primary key,name varchar(50) not null,address1 varchar(50),address2 varchar(50),city varchar(30)
)

文件格式

sql样例
/*changelog标准开头*/
--liquibase formatted sql/*changeset标准开头 author:id*/
--changeset nvoxland:1
/* 设置前置条件属性 */
--preconditions onFail:HALT onError:HALT
/* 设置前置条件sql check,sql格式支支持sqlcheck */
--precondition-sql-check expectedResult:0 SELECT COUNT(*) FROM my_table
create table test1 (id int primary key,name varchar(255)
);
/*rollback标准开头*/
--rollback drop table test1;--changeset nvoxland:2
insert into test1 (id, name) values (1, ‘name 1);
insert into test1 (id,  name) values (2, ‘name 2);--changeset nvoxland:3 dbms:oracle
create sequence seq_test;
其他格式用的时候在补充

跟踪表

DATABASECHANGELOGLOCK (数据库更改日志锁定表)

Liquibase 使用 DATABASECHANGELOGLOCK 表来确保一次只运行一个 Liquibase 实例。
当您进行数据库更新时,Liquibase 会从 DATABASECHANGELOG 表中读取数据,以确定需要运行哪些变更集。为了避免并发更新之间的冲突(如果多个开发人员使用相同的数据库实例,或者集群中的多个服务器在启动时自动运行 Liquibase,则可能会发生冲突),当更新当前正在运行时,DATABASECHANGELOGLOCK 表将该列设置为 1。如果您在此期间进行其他更新,Liquibase 会等到锁释放后再运行它。

DATABASECHANGELOG (数据库更新日志表)

Liquibase 使用 DATABASECHANGELOG 表来跟踪运行了哪些变更集。如果数据库中不存在该表,Liquibase 会自动创建一个表。

命令

Liquibase 附带的几个命令,可以帮助迁移和更改数据库。
主要包含start命令、update命令、rollback命令、inspection 命令、tracking 命令、Maintenance 命令、checks 命令、Hub 命令。
Liquibase命令详细

update

该命令将部署changelog文件中尚未部署到数据库的任何更改。
运行该命令时,Liquibase 会按顺序读取changelog文件中的changset,然后将author 和 id的唯一标识符与存储在 DATABASECHANGELOG 表中的值进行比较。

执行情况

  1. 如果唯一标识符不存在,Liquibase 会将changset应用于数据库。

  2. 如果存在唯一标识符,则将changset的 MD5Sum 与数据库中的 MD<>Sum 进行比较。如果它们不同,Liquibase 将生成一条错误消息,声明有人意外更改了changeset。但是,如果将changeset的属性runOnChange or runAlways 设置为True ,Liquibase 将重新应用changeset。

liquibase使用

基于SpringBoot maven集成Liquibase

  1. 打开pom.xml,添加liquibase依赖
<dependency><groupId>org.liquibase</groupId> <artifactId>liquibase-core</artifactId>
</dependency>
  1. 打开spring配置文件application.properties,添加以下配置
spring:datasource:url: jdbc:postgresql://localhost:5432/yourdatabaseusername: rootpassword: 123456driver-class-name: com.mysql.cj.jdbc.Driverliquibase:#是否启用liquibaseenabled: truechange-log: classpath:db/changelog/changelog.yaml#changlog生效的上下文contexts: dev#第一次执行时,是否清空数据库drop-first: true#changelog生效的标签labels: dev
  1. 在resource文件夹下创建db/changelog/changelog.yaml文件,然后填充以下内容
databaseChangeLog:- includeAll:path: db/changelog/sql/
  1. 然后就可以在db/changelog/sql/文件夹创建你自己的changeset sql格式的文件了;建议文件的命令使用有意义的版本和名字进行命名,比如:01-01-modify-user-table.sql。
  2. sql文件样例
-- liquibase formatted sql--changeset liming:1 ranOn: 2019-07-01 11:00:00.000000000 +0000
create table user
(id   bigint auto_incrementprimary key,name varchar(255) not null
);--changeset liming:2 ranOn: 2019-07-01 11:00:00.000000000 +0000
insert into user (name) values ('liming');
  1. 部署changelog
    6.1.直接启动程序就可以实现改变
    6.2. 在pom.xml中添加liquibase-maven-plugin插件,使用提供的update功能可以实现改变

相关文章:

liquibase学习和使用

文章目录liquibase学习介绍数据库更新日志和数据库更新日志锁定相关概念changelogchangeset的属性preconditionsql样例Contextssql样例Labelsql样例文件格式sql样例其他格式用的时候在补充跟踪表DATABASECHANGELOGLOCK &#xff08;数据库更改日志锁定表&#xff09;DATABASECH…...

redhawk:Low Power Analysis

1.rush current与switch cell 在standby状态下为了控制leakage power我们选择power gating的设计方式&#xff0c;使用power switch cell关闭block/power domain的电源。 power switch的基本介绍可见: 低功耗设计-Power Switch power switch的table中有四种状态&#xff0c;…...

24- 深度学习的模型保存和加载 (TensorFlow系列) (深度学习)

知识要点 keras 保存成hdf5文件, 1.保存模型和参数, 2.只保存参数 1.保存模型和参数 save_modelcallback ModelCheckpoint2. 只保存参数 save_weightscallback ModelCheckpoint save_weights_only True 保存模型: 案例数据: Fashion-MNIST总共有十个类别的图像model.save_w…...

【Echarts图例点击事件】自定义Echarts图例legend点击事件(已解决)

目录先睹为快&#xff08;效果&#xff09;1、实现Echarts多条曲线2、点击echarts触发接口请求2.1 先默认隐藏部分数据2.2 自定义legend图例点击事件3、源码下载地址&#xff08;解压即用&#xff09;**【写在前面】**这下我又不得不说了&#xff0c;还是客户现场使用时想查询一…...

uniapp-首页配置

为了获取到后台服务器发来的数据&#xff0c;需要配置相应的网络地址。位置在main.js入口文件中。 import { $http } from escook/request-miniprogramuni.$http $http // 配置请求根路径 $http.baseUrl https://api-hmugo-web.itheima.net// 请求开始之前做一些事情 $http.…...

支持DDR5,超频更简单,小雕够给力,技嘉B760M小雕WIFI主板上手

目前13代酷睿已经全员集结了&#xff0c;其中全新的i5 13490F应该依然会备受欢迎&#xff0c;当然了&#xff0c;刚上市不久的13代酷睿价格方面还不是很有吸引力&#xff0c;好在12代酷睿在新一代主板上面依然可用&#xff0c;所以预算有限的朋友&#xff0c;完全可用继续使用1…...

fengMap 自定义dom 偏离实际位置;缩放时飘出地图所在区域

目录 一、问题 二、原因及解决方法 三、总结 一、问题 1.前人写了一份代码&#xff0c;很奇怪。使用 new fengmap.FMCompositeMarker添加的复合覆盖物位置是正常的&#xff0c;缩放的时候也是正常的&#xff0c;仍然处于地图内部&#xff1b;但是new fengmap.FMDomMarker添加…...

TryHackMe-黑我杯

黑我杯 相信我们大家在TryHackMe的日积月累都学到了不少东西&#xff0c;从纯萌新到oscp再到更高 我很高兴能将国内各thm玩家聚集到一起&#xff0c;构建一个更好的学习环境和氛围 本次娱乐分两场&#xff1a; Offensive Pentesting — 中等难度Junior Penetration — 容易难…...

【JAVA程序设计】【C00109】基于SSM(非maven)的员工工资管理系统

基于SSM&#xff08;非maven&#xff09;的员工工资管理系统项目简介项目获取开发环境项目技术运行截图项目简介 基于ssm框架非maven开发的企业工资管理系统共分为二个角色&#xff1a;系统管理员、员工 管理员角色包含以下功能&#xff1a; 系统后台登陆、管理员管理、员工信…...

《计算机原理》——HelloWorld.cpp如何运行的

学校《计算机原理》开课啦&#xff01;特此开辟专栏&#xff0c;将一些知识作为笔记&#xff0c;记录下来。 前言 本篇博客知识点来源于educoder的相关题目 1. 相关知识 1.1 计算机语言 计算机语言是人与计算机之间通讯的语言&#xff0c;计算机语言包括编写计算机程序的字符…...

【面试题】在JS循环中使用await会怎么样?

前言这个问题是这样产生的&#xff1f;某天&#xff0c;在学习异步的知识遇到这样一道题&#xff1a;使用Promise的方式&#xff0c;每隔一秒输出数组中一个值const arr [1, 2, 3] ​ arr.reduce((pre, cur) > {return pre.then(() > {returnnewPromise((resolve, rejec…...

Qt QMessageBox详解

文章目录一.QMessageBox介绍枚举属性函数二.QMessageBox的用法1.导入QMessage库2.弹窗提示3.提供选项的弹窗提示4.作为提示&#xff0c;报警&#xff0c;报错提示窗口一.QMessageBox介绍 文本消息显示框(message box)向用户发出情况警报信息并进一步解释警报或向用户提问&…...

Flutter之beamer路由入门指南

beamer路由入门指南 前言使用方法1、路由配置方式1路由配置方式2路由跳转测试现象前言 Beamer是一个很好用的路由组件,本文以beamer1.5.0版本进行说明,前面博主也介绍了其他路由组件 Flutter实战之go_router路由组件入门指南 、 Flutter之Fluro路由组件入门指南 Flutter之Ge…...

「基础篇」机器学习概览

文章目录1. 什么是机器学习2. 引入机器学习3. 应用场景4. 机器学习分类4.1. 有无人类监督4.2. 是否增量学习4.3. 泛化方式5. 主要挑战6. 测试与验证1. 什么是机器学习 机器学习&#xff08;Machine Learning&#xff0c;ML&#xff09;是一个研究领域&#xff0c;让计算机无需…...

揭秘可视化图探索工具 NebulaGraph Explore 是如何实现图计算的

前言 在可视化图探索工具 NebulaGraph Explorer 3.1.0 版本中加入了图计算工作流功能&#xff0c;针对 NebulaGraph 提供了图计算的能力&#xff0c;同时可以利用工作流的 nGQL 运行能力支持简单的数据读取&#xff0c;过滤及写入等数据处理功能。 本文将简单分享下 NebulaGr…...

移动架构43_什么是Jetpack

Android移动架构汇总​​​​​​​ 文章目录一 Android 开发框架演变1 MVC2 MVP3 MVVM二 什么是JetPack三 如何构建支持Jetpack项目一 Android 开发框架演变 1 MVC Model-View-Controller&#xff0c;模型-视图-控制器&#xff0c;Model负责数据管理&#xff0c;View负责UI显…...

TiDB的分布式事务原理探究

事务开启 获取全局授时作为startTS构建一个tikvTxn对象&#xff08;包括snapshot&#xff09;。 事务写 txn.Set方法本质上将kv值写入了一个内存缓存(即kv/memdb_buffer.go中的memDbBuffer)中。该内存kv数据库利用的是golevel提供的功能。 事务回滚 直接将tikvTxn的valid字段…...

【C语言】函数指针和指针函数

文章目录[TOC](文章目录)前言概述函数指针定义&#xff1a;使用&#xff1a;回调函数指针函数前言 今天学一下函数指针 提示&#xff1a;以下是本篇文章正文内容&#xff0c;下面案例可供参考 概述 函数指针&#xff1a;是一个指向函数的指针&#xff0c;在内存空间中存放的…...

Nodejs中npx简介和作用

一、npx简介npm从5.25.2版开始&#xff0c;增加了 npx 命令。方便了我在项目中使用全局包。二、安装Node安装后自带npm模块&#xff0c;可以直接使用npx命令。如果不能使用用&#xff0c;就要手动安装一下。npm install -g npx三、使用npx想要解决的主要问题&#xff0c;就是调…...

Matplotlib精品学习笔记001——绘制3D图形详解+实例讲解

3D图片更生动&#xff0c;或许在时间序列数据的展示上更胜一筹 想法&#xff1a; 学习3D绘图的想法来自科研绘图中。我从事的专业是古植物学&#xff0c;也就是和植物化石打交道。化石有三大信息&#xff1a;1.物种信息&#xff0c;也就是它的分类学价值&#xff1b;2.时间信息…...

学习ifconfig实战技巧,成为网络管理高手

文章目录前言一. ifconfig 命令介绍二. 语法格式及常用选项三. 参考案例3.1 显示网络设备信息3.2 启动和关闭指定的网卡3.3 对指定的网卡设备执行修改IP地址操作3.4 启动和关闭ARP协议3.5 使用ifconfig添加网卡总结前言 大家好&#xff0c;又见面了&#xff0c;我是沐风晓月&a…...

day38|70. 爬楼梯(进阶)、322. 零钱兑换、279.完全平方数

70. 爬楼梯(进阶) 假设你正在爬楼梯。需要 n 阶你才能到达楼顶。 每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢&#xff1f; 示例 1&#xff1a; 输入&#xff1a;n 2 输出&#xff1a;2 解释&#xff1a;有两种方法可以爬到楼顶。 1. 1 阶 1 阶 2. 2…...

SpringBoot全局异常处理

一、目的 当客户端/前端向服务端发送一个请求后&#xff0c;这个请求并不是每次都能完全正确的处理&#xff0c;比如出现一些资源不存在、参数错误或者内部错误等信息的时候&#xff0c;就需要将异常反馈给客户端或者前端。那么这就需要程序有完整的异常处理机制。 在 Java 中所…...

SpringBoot异常处理

目录 一、 错误处理 1. 默认规则 2. 定制错误处理逻辑 二、自定义异常处理 1. 实现 ErrorController 2. RestControllerAdvice/ControllerAdvice ExceptionHandler 实现自定义异常 3. 新建 UserController.class 测试 3 种不同异常的处理 4. 最终效果如下 补充 1. 参…...

《C++ Primer Plus》(第6版)第8章编程练习

《C Primer Plus》&#xff08;第6版&#xff09;第8章编程练习《C Primer Plus》&#xff08;第6版&#xff09;第8章编程练习1. 打印字符串2. CandyBar3. 将string对象的内容转换为大写4. 设置并打印字符串5. max5()6. maxn()7. SumArray()《C Primer Plus》&#xff08;第6版…...

RAD Studio 11.3 Alexandria Crack

RAD Studio 11.3 Alexandria Crack 瞄准最新平台版本-此版本增加了对Android 13和Apple macOS Ventura的官方支持。它还支持Ubuntu 22 LTS和Microsoft Windows Server 2022。 使用生物特征认证-New为FireMonkey移动应用程序提供了新的移动生物特征认证组件。 部署嵌入式InterBa…...

Stm32 iic 协议使用

/* 第1个参数为I2C操作句柄 第2个参数为从机设备地址 第3个参数为从机寄存器地址 第4个参数为从机寄存器地址长度 第5个参数为发送的数据的起始地址 第6个参数为传输数据的大小 第7个参数为操作超时时间 */ HAL_I2C_Mem_Write(&hi2c2,salve_add,0,0,PA_BUFF,sizeof(PA_BUFF…...

Malware Dev 02 - Windows SDDL 后门利用之 SCManager

写在最前 如果你是信息安全爱好者&#xff0c;如果你想考一些证书来提升自己的能力&#xff0c;那么欢迎大家来我的 Discord 频道 Northern Bay。邀请链接在这里&#xff1a; https://discord.gg/9XvvuFq9Wb我拥有 OSCP&#xff0c;OSEP&#xff0c;OSWE&#xff0c;OSED&…...

每日一题29——山峰数组的顶部

符合下列属性的数组 arr 称为 山峰数组&#xff08;山脉数组&#xff09; &#xff1a; arr.length > 3 存在 i&#xff08;0 < i < arr.length - 1&#xff09;使得&#xff1a; arr[0] < arr[1] < ... arr[i-1] < arr[i] arr[i] > arr[i1] > ... &g…...

Linux- 系统随你玩之--好用到炸裂的系统级监控、诊断工具

文章目录1、前言2、lsof介绍2.1、问题来了&#xff1a; 所有用户都可以采用该命令吗&#xff1f;3、 服务器安装lsof3.1、安装3.2、检查安装是否正常。4、lsof 命令4.1、常用功能选项4.2、输出内容4.2.1 、FD和 TYPE列5、 lsof 命令实操常见用法6 、常用组合命令7、 结语1、前言…...

厚街网站建设公司/域名权重

题目描述如下: 方法一:动态规划 在题中每一个阶梯只有两种情况即爬或者不爬&#xff0c;这里我们用一个数组dp存储阶梯的情况&#xff0c;dp[i][1]存储爬阶梯消耗的能量&#xff0c;dp[i][0]存储不爬消耗的能量, 我们要知道第i层阶梯爬的所需消耗的最小能量&#xff0c;则 dp…...

网站建设模式/广州网站制作服务

一、综述二、项目启动三、需求分析四、概要设计五、详细设计与概要设计六、集成测试与系统测试七、交付验收八、系统运维九、配置管理和质量保障概要设计阶段包括&#xff1a;n 项目技术调研n 软件概要设计n 编写概要设计说明书n 概要设计评审1. 项目技术调研要素 描…...

网站建设色彩设计有什么用/seo与网络推广的区别和联系

查看Maven中依赖Jar包Tree结构及导出结构文件&#xff1a; mvn dependency:tree -Doutputoutput.txt 转载于:https://www.cnblogs.com/yhongl/p/6134832.html...

合肥专业网站建设公司哪家好/品牌seo主要做什么

Word基础文本编辑知识教程&#xff1a;1、文字编辑功能所有的基本文本编辑功能都位于“主页”功能区选项卡中。请注意&#xff0c;Word在“主页”选项卡的“字体”类别中提供了几种样式化功能。在文档中键入内容时&#xff0c;将大量使用这些功能和控件。字体样式的第一行是字体…...

不注册公司可以做网站吗/互联网推广是做什么的

何为虚拟DOM虚拟DOM就是普通的js对象&#xff0c;其可以用来描述DOM对象&#xff0c;但是由于不是真正的DOM对象&#xff0c;因此人们把它叫做虚拟DOM。为何出现虚拟DOM手动处理DOM在早期的js应用中&#xff0c;开发人员需要手动处理DOM&#xff0c;手动处理不仅代码繁琐&#…...

wordpress高级版破解版/域名查询官网

你好,欢迎来到第 24 课时,本课时主要讲解 Flink 消费 Kafka 数据开发。 在上一课时中我们提过在实时计算的场景下,绝大多数的数据源都是消息系统,而 Kafka 从众多的消息中间件中脱颖而出,主要是因为高吞吐、低延迟的特点;同时也讲了 Flink 作为生产者像 Kafka 写入数据的…...