Liquibase使用(转)
文章目录
介绍
快速使用
Springboot中
引入依赖
配置日志文件ChangeLog
编写变更记录ChangeSet
Maven中
引入依赖
配置liquibase.properties
编写变更记录ChangeSet
版本回滚
回滚指定次数
回滚到指定tag
输出回滚语句
输出变更记录
一些规范
参考资料
介绍
Liquibase是一个用于数据库重构和迁移的开源工具,通过日志文件的形式记录数据库的变更,然后执行日志文件中的修改,将数据库更新或回滚到一致的状态。它的目标是提供一种数据库类型无关的解决方案,通过执行schema类型的文件来达到迁移。其有点主要有以下:
支持几乎所有主流的数据库,如MySQL, PostgreSQL, Oracle, Sql Server, DB2等;
支持多开发者的协作维护;
日志文件支持多种格式,如XML, YAML, JSON, SQL等;
支持多种运行方式,如命令行、Spring集成、Maven插件、Gradle插件等。
快速使用
Springboot中
引入依赖
<dependencies>
<dependency>
<groupId>org.liquibase</groupId>
<artifactId>liquibase-core</artifactId>
</dependency>
<dependency>
</dependencies>
配置日志文件ChangeLog
- 在
resources
目录中创建/db/changelog
目录作为日志文件存放目录 - 在目录中创建日志文件
db.changelog-master.yml
- 在
application.yml
中配置changelog路径
spring:
liquibase:
# 不配置默认会查找'classpath:/db/changelog/db.changelog-master.yaml'文件
change-log: 'classpath:/db/changelog/db.changelog-master.yml'
编写变更记录ChangeSet
- 编写初始数据库脚本
databaseChangeLog:
- changeSet:
# 唯一id,建议使用Flayway的命名格式'V<version>[_<SEQ>][__description]'
id: V1.0_0__init
# 作者
author: Cheivin
# 描述
comment: "初始化脚本内容,加载初始数据"
# 启用事物
runInTransaction: true
# 变更脚本
changes:
# 创建表格
- createTable:
tableName: user
columns:
- column:
name: id
type: int
autoIncrement: true
constraints:
primaryKey: true
nullable: false
remarks:
- column:
name: username
type: VARCHAR(50)
constraints:
nullable: false
- column:
name: password
type: VARCHAR(50)
constraints:
nullable: false
# 加载数据
- loadData:
tableName: user
columns:
- column:
header: username
name: username
- column:
header: password
name: password
encoding: UTF-8
file: db/data/init-data.csv
# 标记,用于回滚时指定版本
- tagDatabase:
tag: V1.0_0__init
- 运行项目后,查看数据库
- 修改changelog,增加变更数据库脚本
# 在databaseChangeLog后追加
- changeSet:
id: V1.0_1__mod
author: Cheivin
comment: "修改用户表,增加账单表"
runInTransaction: true
changes:
# 通过标准格式添加字段
- addColumn:
# 目标表
tableName: user
columns:
- column:
name: state
type: tinyint
# 默认值
defaultValueNumeric: 0
remarks: '用户状态,0:未激活,1:激活,-1:禁用'
- column:
name: identity
type: int
# 默认值
defaultValueNumeric: 999
remarks: '用户身份,999:管理员'
# 通过sql语句操作数据库
- sql:
sql: insert into user (username,password,state,identity) values ('admin','admin',1,999)
# 通过sql文件操作数据库
- sqlFile:
encoding: utf8
path: db/changelog/V1.0_1__mod_bill.sql
- tagDatabase:
tag: V1.0_1__mod
# 回滚语句
- rollback:
- delete:
tableName: user
where: username='admin'
- dropTable:
tableName: user_bill
Maven中
引入依赖
<build>
<plugins>
<plugin>
<groupId>org.liquibase</groupId>
<artifactId>liquibase-maven-plugin</artifactId>
<version>3.6.3</version>
<configuration>
<!-- 配置文件,必须放在resource目录下 -->
<propertyFile>src/main/resources/liquibase/liquibase.properties</propertyFile>
</configuration>
<executions>
<!-- 默认mvn启动时执行更新操作 -->
<execution>
<phase>process-resources</phase>
<goals>
<goal>update</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
配置liquibase.properties
# 日志文件路径,必须放在resource目录下
changeLogFile=src/main/resources/liquibase/db.changelog-master.yml
# 数据库地址
url=jdbc:mysql://localhost:3306/liquibase_mvn?useSSL=false&useUnicode=true&characterEncoding=UTF-8
# 账号
username=root
# 密码
password=root
编写变更记录ChangeSet
- 编写初始数据库脚本
databaseChangeLog:
- changeSet:
# 唯一id,建议使用Flayway的命名格式'V<version>[_<SEQ>][__description]'
id: V1.0_0__init
# 作者
author: Cheivin
# 描述
comment: "初始化脚本内容,加载初始数据"
# 启用事物
runInTransaction: true
# 变更脚本
changes:
# 创建表格
- createTable:
tableName: user
remarks: '用户表'
columns:
- column:
name: id
type: int
autoIncrement: true
constraints:
primaryKey: true
nullable: false
- column:
name: username
type: VARCHAR(50)
constraints:
nullable: false
remarks: '用户名'
- column:
name: password
type: VARCHAR(50)
constraints:
nullable: false
remarks: '密码'
# 加载数据
- loadData:
tableName: user
columns:
- column:
header: username
name: username
- column:
header: password
name: password
encoding: UTF-8
file: src/main/resources/liquibase/data/init-data.csv
# 标记,用于回滚时指定版本
- tagDatabase:
tag: V1.0_0__init
- 运行项目后,查看数据库
- 修改changelog,增加变更数据库脚本
# 在databaseChangeLog后追加
- changeSet:
id: V1.0_1__mod
author: Cheivin
comment: "修改用户表,增加账单表"
runInTransaction: true
changes:
# 通过标准格式添加字段
- addColumn:
# 目标表
tableName: user
columns:
- column:
name: state
type: tinyint
# 默认值
defaultValueNumeric: 0
remarks: '用户状态,0:未激活,1:激活,-1:禁用'
- column:
name: identity
type: int
# 默认值
defaultValueNumeric: 999
remarks: '用户身份,999:管理员'
# 通过sql语句操作数据库
- sql:
sql: insert into user (username,password,state,identity) values ('admin','admin',1,999)
# 通过sql文件操作数据库
- sqlFile:
encoding: utf8
path: src/main/resources/liquibase/V1.0_1__mod_bill.sql
- tagDatabase:
tag: V1.0_1__mod
# 回滚语句
- rollback:
- delete:
tableName: user
where: username='admin'
- dropTable:
tableName: user_bill
版本回滚
回滚指定次数
命令格式
mvn liquibase:rollback -Dliquibase.rollbackCount=次数
eg:
mvn liquibase:rollback -Dliquibase.rollbackCount=1
回滚到指定tag
命令格式
mvn liquibase:rollback -Dliquibase.rollbackTag=tag名称
eg:
mvn liquibase:rollback -Dliquibase.rollbackTag=V1.0_0__init
输出回滚语句
命令格式
mvn liquibase:rollbackSQL -Dliquibase.rollbackCount=次数
mvn liquibase:rollbackSQL -Dliquibase.rollbackTag=tag名称
将会在target/liquibase目录中生成migrate.sql文件
输出变更记录
命令格式
mvn liquibase:dbDoc
将会在target/liquibase目录中生成dbDoc目录,打开index.html可查看
一些规范
ChangeSet id建议使用Flayway的命名格式V<version>[_<SEQ>][__description],如V1.0_0__init。或使用[任务ID]-[日期]-[序号],如T100-20190705-001
ChangeSet必须填写author
Liquibase禁止对业务数据进行sql操作
所有表,列要加remarks进行注释
已经执行过的ChangeSet严禁修改。
不要随便升级项目liquibase版本,特别是大版本升级。不同版本ChangeSet MD5SUM的算法不一样。
参考资料
官方文档 http://www.liquibase.org/documentation/
changeset配置文档 http://www.liquibase.org/documentation/changes/index.html
————————————————
版权声明:本文为CSDN博主「Cheivin」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/zhao0416/article/details/94733610
————————————————
版权声明:本文为CSDN博主「Cheivin」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/zhao0416/article/details/94733610
Liquibase使用(转)的更多相关文章
- liquibase的使用
前言 liquibase是一个数据库持续集成插件.独立于数据库存在,oracle,mysql,db2,h2,sql server,postgresql都能使用.它使用配置文件来更新数据库结构,并加入版 ...
- Spring3+Mybatis3+Mysql+ivy+liquibase
Spring3+Mybatis3+Mysql+ivy+liquibase 集成 近一周时间所学技术:整合Spring+MyBatis+MySql+ivy+liquibase Mybatis:是一个基于 ...
- liquibase之快速入门
第一步: 创建一个Changelog File: 这个database Changelog file列举了数据库中所有的改变情况,该文件是以xml为基础的,下面是一个空的xml文件: <?xm ...
- Liquibase的简单使用
LiquiBase是一个用于数据库重构和迁移的开源工具,通过日志文件的形式记录数据库的变更,然后执行日志文件中的修改,将数据库更新或回滚到一致的状态.它的目标是提供一种数据库类型无关的解决方案,通过执 ...
- [心得] 如何利用liquibase進行資料庫版本控制 - 實際練習
透過上一篇的基本觀念介紹,希望大家應該有一點點感覺了! 這篇我們就來做個簡單的版本演練,加深印象吧! 我使用的環境如下 System : Windows 7 Database : SQL Server ...
- flyway和liquibase的使用样例
在代码上我们有svn和git等诸多的版本控制方法. 但是在数据库上却没有相应的工具.一度导致多环境见的数据库同步难以维持. flyway和liquibase都是常见的数据库版本控制工具. flyway ...
- [心得] 如何利用liquibase進行資料庫版本控制 - 基礎觀念
前言 - 會寫這篇除了是要記錄一下使用的過程之外,也是發現到網路上找來的教學幾乎都是跟其它環境做結合 比較沒有單純利用command進行的流程.也沒有整體觀念的介紹,所以將我所理解的整理分享給大家. ...
- LiquiBase 学习
preconditions mysql database is installed maven has been setted up properly add depedenceies apply p ...
- Liquibase使用入门
1.LiquiBase简介 LiquiBase是一个用于数据库重构和迁移的开源工具,通过日志文件的形式记录数据库的变更,然后执行日志文件中的修改,将数据库更新或回滚到一致的状态.LiquiBase的主 ...
- eclipse liquibase 插件
http://marketplace.eclipse.org/category/free-tagging/liquibase http://marketplace.eclipse.org/market ...
随机推荐
- tp5支付宝和微信支付
一.生成二维码给用户进行扫码支付 1.先在vendor目录下加入支付宝和微信支付的引用 2.付款处调用 /** * 订单支付接口 * * @api {post} {:url('order/pay')} ...
- 关于Python中的lambda
lambda是Python编程语言中使用频率较高的一个关键字.那么,什么是lambda?它有哪些用法?网上的文章汗牛充栋,可是把这个讲透的文章却不多.这里,我们通过阅读各方资料,总结了关于Python ...
- 关于python中的包,模块导入的问题详解(二)
from import导入 紧接着的是from xx import xx 语法 1 ################ 2 from my_moudule import name 3 print(na ...
- Replication-Manager
MYSQL5.7下搭建Replication-Manager 环境说明 在主机1,主机2,主机3上安装MySQL服务端和客户端. 主机1 主机2 主机3 操作系统 CentOS7.4 CentOS7. ...
- Mysql-Sqlalchemy-ORM-多外键关联
创建表结构:orm_many_fk.py from sqlalchemy import Integer, ForeignKey, String, Column,create_engine from s ...
- python-迭代器实现异步(在串行中)
import timedef consumer(name): print('%s 准备吃包子啦!' %name) while True: baozi = yield #yield不但可以返回值还可以接 ...
- SSD性能测试
Tested by CrystalDiskMark 7 * MB/s = 1,000,000 bytes/s [SATA/600 = 600,000,000 bytes/s]* KB = 1000 b ...
- vue.js中,如何把text按html格式化显示
先说方法:v-html = "你的字符串" <el-table-column type="expand" label="详情" hea ...
- Sublime Text 3配置浏览默认路径为localhost
1.在 Sublime Text 3 中,安装 SideBarEnhancements 侧边栏增强插件.(注意:安装插件之前需要安装包管理工具,参考这里) 2.SideBarEnhancements ...
- vue学习(2)-过滤器
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...