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. 文件 结构  

3.1标签 指路常用到的一些 changeset

3.2. 标签

的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);

指定的是changelog的目录,而不是为文件,如:

 

  4.new一个databaseChangeLog文件   new 201908091500_T_TABLE_NAME_DDL 的xml文件



 
	
	
	
    

 

你可能感兴趣的:(Liquibase)