如何解决liquibase升级后liquibase校验和验证失败的问题



在我的项目中,我刚刚尝试将liquibase从3.2.2升级到3.4.2(包括jar和maven插件)。编辑:升级到3.3.x时相同。因此,现在启动应用程序会出现以下错误:

Caused by: liquibase.exception.ValidationFailedException: Validation Failed:
   4 change sets check sum
   src/main/resources/changelogs/xxx_add_indices_to_event_tables.xml::xxx-add_indices_to_event_tables::xxx is now: 7:0fc8f1faf484a59a96125f3e63431128

这适用于50个中的4个变更集,所有这些变更集都添加了索引,例如:

<createIndex indexName="idx_eventtype" tableName="events">
    <column name="eventtype" type="varchar(64)"/>
</createIndex>

虽然我可以在本地解决这个问题,但在所有运行环境中手动解决这个问题将是一个巨大的痛苦。这是一个错误,还是有一些变通方法?

您还可以使用<changeSet><validCheckSum>子标记将新的校验和添加为有效的校验和。

此外,请查看关于错误CORE-1950的注释。您可以在两个liquibase版本上都将日志级别设置为"调试",看看是否可以在校验和创建的日志输出中找到差异。

使用类似于的子标签

<changeSet id="00000000000009" author="system">
    <validCheckSum>7:19f99d93fcb9909c7749b7fc2dce1417</validCheckSum>
    <preConditions onFail="MARK_RAN">
        <sqlCheck expectedResult="0">SELECT COUNT(*) FROM users</sqlCheck>
    </preConditions>
    <loadData encoding="UTF-8" file="users.csv" separator=";" tableName="users">
        <column name="active" type="boolean" />
        <column name="deleted" type="boolean" />
    </loadData>
</changeSet>

您应该记住,validCheckSum标记的值是变更集的新校验和。

mvn liquibase:clearCheckSums

将清除checkSums

清除校验和对您有什么用?当然,它们将被重新计算。请参阅此处的相关问题。希望对有所帮助

使用渐变./gradlew liquibaseClearChecksums

最新更新