2

我已将 future-rollback 标记添加到我的 ant 脚本中。我想要做的(我认为future-rollback 是我正在寻找的)是生成一个sql 回滚脚本,但不执行它(回滚脚本必须与sql 脚本一起交付是我客户的要求)。

我的变更日志文件有许多变更集,其中一些包含 <sqlFile>标签。

例如:

<databaseChangeLog ...>

<include file="latest/somesqlprocedure.xml" relativeToChangelogFile="true"/>

</databaseChangelog...>

latest/somesqlprocedure.xmlsqlFile标签的地方。

<databaseChangeLog xmlns="http://www.liquibase.org/xml/ns/dbchangelog/1.9" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog/1.9 http://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-1.9.xsd">

<sqlFile path="${changelog.dir}/latest/myprocedure.sql" splitStatements="false" />

</changeSet>

</databaseChangeLog>

当我运行 ant 脚本时,出现以下错误

liquibase.exception.ChangeLogParseException:无效的迁移文件:<sqlfile path=${changelog.dir}/latest/myprocedure.sql> -找不到文件

有谁知道发生了什么?

这是 build.xml 文件的片段

<target name="db-future-rollback" depends="init">
        <rollbackFutureDatabase
                    changeLogFile="${db.changelog.file}"
                    driver="${database.driver}"
                    url="${database.url}"
                    username="${database.username}"
                    password="${database.password}"
                    outputfile="${database.rollback.dir}"
                    promptOnNonLocalDatabase="${prompt.user.if.not.local.database}"
                    classpathref="project.classpath"
                    >
            </rollbackFutureDatabase>

    </target>

提前致谢。

4

1 回答 1

2

问题可能来自在 sqlFile 中使用绝对路径,而不是类路径相对路径。类路径相对路径是 liquibase 最初支持的,并且经过更好的测试。最近添加了绝对路径选项,futureRollbackSql 代码可能没有打补丁支持。

您可以使用相对路径尝试 sqlFile 吗?

附带说明一下,相对路径选项通常更好,因为在 databasechangelog 表中使用文件名来记录哪些变更集已运行。如果您使用绝对路径,则存储整个路径,并且如果您尝试从不同的路径重新运行更改日志(或从不同的机器上针对相同的数据库运行),liquibase 会认为它是不同的更改集并尝试重新运行它。

于 2010-02-10T21:14:40.760 回答