ロールバック タグは、データベースの構成をチェックポイントするように設計されています。
次のコマンドは、データベース構成を 3 つの変更セット分ロールバックし、「checkpoint」というタグを作成します。
mvn liquibase:rollback -Dliquibase.rollbackCount=3
mvn liquibase:tag -Dliquibase.tag=checkpoint
これで、データベースを更新し、任意の段階で rollback タグを使用してその時点にロールバックできます。
mvn liquibase:rollback -Dliquibase.rollbackTag=checkpoint
または、代わりにロールバック SQL を生成します。
mvn liquibase:rollbackSQL -Dliquibase.rollbackTag=checkpoint
修正例
最初は、liquibase Maven プラグインの構成方法を理解するのが難しいと感じました。念のため、私が使用した例を次に示します。
liquibase の更新は自動的に実行されるように構成されており、その後、現在の Maven リビジョン番号でデータベースにタグが付けられます。
<project>
<modelVersion>4.0.0</modelVersion>
<groupId>com.myspotontheweb.db</groupId>
<artifactId>liquibase-demo</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<!-- Liquibase settings -->
<liquibase.url>jdbc:h2:target/db1/liquibaseTest;AUTO_SERVER=TRUE</liquibase.url>
<liquibase.driver>org.h2.Driver</liquibase.driver>
<liquibase.username>user</liquibase.username>
<liquibase.password>pass</liquibase.password>
<liquibase.changeLogFile>com/myspotontheweb/db/changelog/db-changelog-master.xml</liquibase.changeLogFile>
<liquibase.promptOnNonLocalDatabase>false</liquibase.promptOnNonLocalDatabase>
</properties>
<dependencies>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<version>1.3.162</version>
</dependency>
</dependencies>
<profiles>
<profile>
<id>dbupdate</id>
<activation>
<activeByDefault>true</activeByDefault>
</activation>
<build>
<plugins>
<plugin>
<groupId>org.liquibase</groupId>
<artifactId>liquibase-maven-plugin</artifactId>
<version>2.0.2</version>
<executions>
<execution>
<phase>process-resources</phase>
<configuration>
<tag>${project.version}</tag>
</configuration>
<goals>
<goal>update</goal>
<goal>tag</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
</profile>
</profiles>
</project>
Liquibase は現在、標準のライフサイクルの一部として構成されているため、次のように実行できます。
mvn clean compile