前言

      一家人除了我都去旅游了,我这项请假,请不动啊。既然在家了,闲着也是闲着,就复盘下最近的工作,今天就复盘表结构管理吧,随系统启动的,不是flyway,而是另一个liquibase,个人觉得它比fly更优秀。
现在当家了,才知道当小弟的快乐,现在比当核心的时候更累了,不过这也正常。但是实际上米并没有拿多,这该死的年龄,怀恋啊我们的青春啊。回想这一路走来,因为性格问题,被压制太久了,其实有些时候并不是你能力不够,而是上面不愿意让你发展…


一、Liquibase?

1.Liquibase是什么

  • Liquibase 是一个开源的数据库版本控制工具,主要用于自动管理数据库结构(Schema)变更,确保数据库在不同环境(开发、测试、生产)中的结构一致性。
  • Liquibase 是数据库的 Git。就像你用 Git 来管理代码版本一样,Liquibase 用来管理数据库结构的变更记录。

2.它能做什么

  • 自动执行数据库迁移脚本(建表、加字段、加索引等)

  • 将变更记录存入数据库,确保不重复执行

  • 支持回滚数据库操作

  • 适用于 CI/CD 自动部署流程

  • 多种格式支持:XML、YAML、JSON、SQL

3.基本原理

  • 每次你要对数据库做结构修改,就写一个“changelog”文件(变更日志)。

  • Liquibase 执行后会在数据库中建一个表叫 DATABASECHANGELOG,记录每次执行过的变更。

  • 之后每次运行时,Liquibase 会比对哪些变更没有执行过,只执行新的部分。

4.它适合什么场景

  • 使用微服务、多个环境(本地、测试、线上)的团队

  • 不希望 DBA 手工发 SQL 的项目

  • 想把数据库脚本版本控制起来的工程化团队

5.它与 Flyway 有什么区别?

      Liquibase 和 Flyway 是两大主流的 数据库迁移工具,它们都能自动执行数据库变更,但各有特点。下面是它们之间的核心区别对比:

功能LiquibaseFlyway
支持多种格式YAML / XML / JSON / SQL仅支持 SQL 和 Java
可声明式(非纯 SQL)否(主要是 SQL)
脚本命名规则灵活changelog-xxx.yaml必须 V1__init.sql
顺序控制方式id 字段控制顺序文件名控制顺序
支持数据库种类更广泛(几十种)主流数据库为主
数据库记录执行历史|DATABASECHANGELOG 表|flyway_schema_history 表|
支持回滚原生支持手动写 rollback 脚本
自动执行迁移
Spring Boot 默认集成工具非默认默认集成

结论汇总:

  • Liquibase 更灵活,支持声明式写法,不用写原生 SQL。Flyway 更适合 DBA 写 SQL。
  • Flyway 严格依赖文件名排序执行脚本,而 Liquibase 通过 id + author 明确指定每条变更。
  • 两者都支持 MySQL、PostgreSQL、Oracle、SQL Server 等主流数据库。
  • Liquibase 原生支持 rollback,而 Flyway 不支持自动回滚,需人工写反向脚本。
  • Spring Boot 默认集成 Flyway(spring-boot-starter-data-jpa 会自动检测 Flyway 脚本),Liquibase 需要显式加依赖。

二、使用步骤

1.引入库

<dependency><groupId>org.liquibase</groupId><artifactId>liquibase-core</artifactId>
</dependency>

2.建目录

      一般是在resources下建db目录,下面方master.xml,建mysql目录。当然也可以在resources下建其他名称的目录,在xml文件里指定的目录对得上就行。
master.xml

<databaseChangeLogxmlns="http://www.liquibase.org/xml/ns/dbchangelog"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangeloghttp://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-3.1.xsd"><!-- <include file="db/mysql/changelog.sql" relativeToChangelogFile="false"/>--><includeAll path="db/mysql"/></databaseChangeLog>

mysql是用来存sql的
这里在mysql目录下就建一个文件changelog.sql,我是不太愿意一个人建一个文件的,都在一个文件里写好提交的id注释就行了。

--liquibase formatted sql-- changeset zw:202506291113
ALTER TABLE enterprise_matters CHANGE is_topic is_topic int(11) NULL COMMENT '是否主题,0否,1是' AFTER applicable_region;
-- comment:修改字段排序

      一直在这个文件下以-- changeset zw:提交id,-- comment:注释 结尾就行。
注意,若果是在原始语句上修改,注意提交的id要往后变,当然一般情况是不支持这样搞的,还是建议再次写一个语句


总结

  • 就是这么简单,sql就管理起来了,个人觉得特别适合敏捷开发
  • 领头、领衔确实难点,需要考虑的事情多,最最重要的的是还要技术支撑,不然顶不住啊
    就写到这里,加油,uping!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/pingmian/88149.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/88149.shtml
英文地址,请注明出处:http://en.pswp.cn/pingmian/88149.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

go-carbon v2.6.10发布,轻量级、语义化、对开发者友好的 golang 时间处理库

carbon 是一个轻量级、语义化、对开发者友好的 Golang 时间处理库&#xff0c;提供了对时间穿越、时间差值、时间极值、时间判断、星座、星座、农历、儒略日 / 简化儒略日、波斯历 / 伊朗历的支持。 carbon 目前已捐赠给 dromara 开源组织&#xff0c;已被 awesome-go 收录&am…

【AI News | 20250708】每日AI进展

AI Repos 1、claude-code-templates Claude Code Templates是一款全面的命令行工具&#xff0c;旨在为不同编程语言和框架&#xff08;如JavaScript/TypeScript、Python等&#xff0c;Go和Rust即将推出&#xff09;提供优化的Claude Code配置。它通过交互式设置、自动化钩子&a…

Nginx源码安装+静态站点部署指南(CentOS 7)

安装包&#xff1a;可自行前往我的飞书下载 Docs 也可以进入 nginx 官网&#xff0c;下载自己所需适应版本 nginx 开始安装nginx 1. 创建准备目录 cd /opt mkdir soft module # 创建软件包和源码解压目录 2. 安装依赖环境 yum -y install make zlib zlib-devel gcc-c l…

交换机的核心原理和作用

一、交换机的核心原理交换机是一种用于连接多台设备的网络硬件&#xff0c;其核心原理基于二层网络&#xff08;数据链路层&#xff09;的 MAC 地址寻址1. MAC 地址学习与存储当交换机接收到数据帧时&#xff0c;会读取帧中的源 MAC 地址&#xff0c;并将该地址与对应的端口号记…

【工具变量】上市公司企业金融强监管数据、资管新规数据(2001-2024年)

数据简介&#xff1a;参考顶刊《经济研究》李青原&#xff08;2022&#xff09;老师的做法&#xff0c;Post 为时间虚拟变量&#xff0c;根据资管新规实施的时间&#xff0c;当观测期为2018 年上半年及之后时&#xff0c;Post 取值1&#xff0c;否则取值0。PreFin 为资管新规实…

CSS Grid与Flexbox布局实战对比

概述 CSS布局技术在过去几年经历了重大变革&#xff0c;从传统的基于浮动和定位的方法&#xff0c;到现在强大的Flexbox和Grid布局系统。这两种现代布局方法极大地简化了复杂界面的开发过程&#xff0c;但它们各自适用于不同的场景。本文将对Flexbox和Grid进行深入比较&#x…

[Pytest][Part 4]多种测试运行方式

实现需求2&#xff1a;有两种运行测试的方式&#xff1a;通过config配置文件运行&#xff0c;测试只需要修改config配置文件cmdline 运行这里是新建一个config类来存储所有的测试配置&#xff0c;以后配置有修改的话也只需要修改这个类。根据目前的测试需求&#xff0c;config中…

平衡二叉树的删除操作

对于平衡二叉树的操作应对与考试只需要模拟出过程即可&#xff0c;且他的过程和插入的平衡方法一样&#xff0c;不一样的只是对于平衡因子的计算上。接下来我将给出方法①删除结点&#xff08;方法同“二叉排序树”&#xff09; ②一路向北找到最小不平衡子树&#xff0c;找不到…

Spark 4.0的 VariantType 类型优点以及使用分析

背景 本文基于Spark 4.0。 总结 对于半结构化的数据来说&#xff0c;我们一般会有两种方式进行存储: 第一种是存储为JSON String,这种可以保证Schema free&#xff0c;但是在使用的时候得解析为JSON&#xff0c;从而进行运算操作。 第二种是存储为Struct类型&#xff0c;这种虽…

17-C#封装,继承,多态与重载

C#封装继承多态 1. 2. 3.多态 public abstract class animal//抽象类 {public abstract void eat();//抽象方法 } public class cat : animal//继承 {public override void eat()//重写{messagebox.show("cat eat");} } public class dog: animal//继承 {public over…

恒创科技:香港站群服务器做seo站群优化效果如何

香港站群服务器做 SEO 站群优化效果如何?在当前搜索引擎优化竞争日益激烈的环境下&#xff0c;越来越多的企业开始关注站群策略这一高效的 SEO 手段。作为亚洲重要的网络枢纽&#xff0c;香港站群服务器因其独特优势&#xff0c;正成为实施 SEO 站群优化的热门选择。本文将客观…

Linux-进程管理

Linux-进程管理Linux 进程管理1. 进程的含义2. 进程状态3. 进程工作模式4. 守护进程5. 进程查看命令5.1 ps 命令5.2 top 命令5.3 pstree 命令6. 终止进程的 kill 命令7. 前后台运行8. 暂停进程9. 进程文件系统 /proc10. 定时任务管理10.1 at 命令10.2 batch 命令10.3 cron 与 c…

OpenCV图像增强秘籍:高通滤波与特效艺术

> 在数字图像处理领域,边缘是图像最富信息的区域。掌握高通滤波技术,你就能让图像中的隐藏细节"跃然纸上",甚至创造惊艳的艺术效果。 ## 一、图像增强与高通滤波基础 ### 1.1 图像增强的核心目标 图像增强不是简单的美化,而是通过技术手段**突出重要特征*…

347. 前K个高频元素

题目&#xff1a; 给你一个整数数组 nums 和一个整数 k &#xff0c;请你返回其中出现频率前 k 高的元素。你可以按 任意顺序 返回答案。 示例&#xff1a; 输入: nums [1,1,1,2,2,3], k 2 输出: [1,2] 解题思路&#xff1a; 要返回出现频率前k高的元素&#xff0c;那么我们首…

C++面试冲刺笔记1:虚函数的基本工作原理

C面试冲刺笔记1&#xff1a;虚函数的基本工作原理 前言 ​ 笔者最近开始投简历&#xff0c;出于应对之后快速的面试流程需求&#xff0c;这里准备的是将常见的C八股文进行总结&#xff0c;从而方便自己进行学习&#xff0c;检查和评估。 什么是虚函数 ​ 虚函数&#xff0c;本质…

Spring Boot 事务失效问题详解:原因、场景与解决方案

在 Spring Boot 开发中&#xff0c;事务管理是保证数据一致性和完整性的核心机制。然而&#xff0c;许多开发者在使用 Transactional 注解时&#xff0c;可能会遇到事务失效的问题&#xff0c;导致数据异常或业务逻辑错误。本文将深入分析 Spring Boot 中事务失效的常见原因&am…

Python-文件操作-StringIO和BytesIO-路径操作-shutil模块-csv,ini序列化和反序列化-argparse使用-学习笔记

序 欠4年前的一份学习笔记&#xff0c;献给今后的自己。 文件操作 冯诺依曼体系架构CPU由运算器和控制器组成 运算器&#xff0c;完成各种算数运算、逻辑运算、数据传输等数据加工处理 。 控制器&#xff0c;控制程序的执行 存储器&#xff0c;用于记忆程序和数据&#xff0c;例…

LLM的表征做减法的是什么,自然语言是一个矩阵,怎么进行减法的

LLM的表征做减法的是什么,自然语言是一个矩阵,怎么进行减法的 有个假设:就是最后一个词语融合了前面词语的信息 减法操作主要用于提取模型内部表征中的"诚实性"概念向量。具体来说,这是通过对比诚实和不诚实场景下的模型隐藏状态实现的。 import torch from t…

Java创建型模式---单例模式

单例模式基础概念单例模式是一种创建型设计模式&#xff0c;其核心思想是确保一个类仅有一个实例&#xff0c;并提供一个全局访问点来获取这个实例。在 Java 中实现单例模式主要有以下关键点&#xff1a;私有构造函数 - 防止外部通过new关键字创建实例静态实例变量 - 类内部持有…

详解Kafka重平衡机制详解

Kafka 的重平衡机制&#xff08;Rebalance&#xff09;是确保消费者组内成员动态变化&#xff08;如新成员加入、现有成员退出或崩溃、订阅主题分区数变化&#xff09;时&#xff0c;分区所有权能合理、公平地重新分配的核心机制。其目标是保证所有分区都有消费者处理&#xff…