liquibase changelog文件
1.LiquiBase在执行changelog时,会在数据库中插入两张表:DATABASECHANGELOG和DATABASECHANGELOGLOCK,分别记录changelog的执行日志和锁日志。
LiquiBase在执行changelog中的changeSet时,会首先查看DATABASECHANGELOG表,如果已经执行过,则会跳过(除非changeSet的runAlways属性为true),如果没有执行过,则执行并记录changelog日志;
或者可是在databasechangelog表中删除这条changeset的执行记录,然后再执行这个changeset
2.liquibase 运行中出现 INFO … Liquibase: Waiting for changelog lock....是有机器锁表了 参考 数据库重构工具 LiquiBase(5 Liquibase被锁)
--查看哪个机器锁表
SELECT * FROM DATABASECHANGELOGLOCK;
--如果是本机锁表,解锁语句
UPDATE DATABASECHANGELOGLOCK SET locked=0, lockgranted=null, lockedby=null WHERE id=1
3. <databaseChangeLog>文件 结构
3.1<changeSet>标签 指路常用到的一些 changeset
3.2. <include>与<includeAll>标签
<include>的file属性表示要包含的changelog文件的路径,这个文件可以是LiquiBase支持的任意格式,
relativeToChangelogFile如果为true,则表示file属性表示的文件路径是相对于根changelog 而不是CLASSPATH的,默认为false。
例如如下sql文件 201908091500_T_TABLE_NAME.sql
-- liquibase formatted sql
-- changeset ds:201908091500_T_TABLE_NAME.T_TABLE_NAME failOnError:true dbms:oracle
ALTER TABLE T_TABLE_NAME ADD NEW_COLUMN NUMBER(6);
<include file="201908091500_T_TABLE_NAME.sql" relativeToChangelogFile="true" />
<includeAll>指定的是changelog的目录,而不是为文件,如:
<includeAll path="com/example/changelogs/"/>
4.new一个databaseChangeLog文件 new 201908091500_T_TABLE_NAME_DDL 的xml文件
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<databaseChangeLog xmlns="http://www.liquibase.org/xml/ns/dbchangelog"
xmlns:ext="http://www.liquibase.org/xml/ns/dbchangelog-ext" 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.4.xsd http://www.liquibase.org/xml/ns/dbchangelog-ext http://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-ext.xsd">
<changeSet author="ds" id="201908091500_T_TABLE_NAME_DDL-1">
</changeSet>
<include file="201908091500_T_TABLE_NAME.sql" relativeToChangelogFile="true" />
</databaseChangeLog>