分阶段传播飞路剖面

时间:2015-02-03 19:09:52

标签: maven flyway

我正在尝试使用flyway-maven-plugin创建单独的配置文件,但相位定义无法正常工作。这意味着,当我使用两个配置文件时,我在执行时出错,因为我猜“drop-create-database”使用“migrate-database”中的配置,因此它失败了。有没有人知道如何解决它?

    <profiles>
    <profile>
        <id>drop-create</id>
        <build>
            <plugins>
                <plugin>
                    <groupId>org.flywaydb</groupId>
                    <artifactId>flyway-maven-plugin</artifactId>
                    <version>3.1</version>
                    <configuration>
                        <driver>net.sourceforge.jtds.jdbc.Driver</driver>
                        <table>MIGRATION_LOG</table>
                        <sqlMigrationPrefix>EMP_</sqlMigrationPrefix>
                        <skip>false</skip>
                    </configuration>
                    <executions>
                        <execution>
                            <id>drop-create-database</id>
                            <!-- Need to garantee order of execution -->
                            <phase>package</phase>
                            <goals>
                                <goal>clean</goal>
                                <goal>migrate</goal>
                            </goals>
                        </execution>
                    </executions>
                </plugin>
            </plugins>
        </build>
    </profile>
    <profile>
        <id>migrate</id>
        <build>
            <plugins>
                <plugin>
                    <groupId>org.flywaydb</groupId>
                    <artifactId>flyway-maven-plugin</artifactId>
                    <version>3.1</version>
                    <configuration>
                        <driver>net.sourceforge.jtds.jdbc.Driver</driver>
                        <table>MIGRATION_LOG</table>
                        <sqlMigrationPrefix>ALL_</sqlMigrationPrefix>
                        <skip>false</skip>
                    </configuration>
                    <executions>
                        <execution>
                            <id>migrate-database</id>
                            <phase>pre-integration-test</phase>
                            <goals>
                                <goal>migrate</goal>
                            </goals>
                        </execution>
                    </executions>
                </plugin>
            </plugins>
        </build>
    </profile>
</profiles>

1 个答案:

答案 0 :(得分:2)

您必须指定每次执行的配置而不是每个插件。否则,同一插件的后续配置将覆盖以前的配置。

这意味着你的pom.xml应该是这样的:

<profiles>
<profile>
    <id>drop-create</id>
    <build>
        <plugins>
            <plugin>
                <groupId>org.flywaydb</groupId>
                <artifactId>flyway-maven-plugin</artifactId>
                <version>3.1</version>
                <executions>
                    <execution>
                        <id>drop-create-database</id>
                        <!-- Need to garantee order of execution -->
                        <phase>package</phase>
                        <goals>
                            <goal>clean</goal>
                            <goal>migrate</goal>
                        </goals>
                        <configuration>
                            <driver>net.sourceforge.jtds.jdbc.Driver</driver>
                            <table>MIGRATION_LOG</table>
                            <sqlMigrationPrefix>EMP_</sqlMigrationPrefix>
                            <skip>false</skip>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>
</profile>
<profile>
    <id>migrate</id>
    <build>
        <plugins>
            <plugin>
                <groupId>org.flywaydb</groupId>
                <artifactId>flyway-maven-plugin</artifactId>
                <version>3.1</version>
                <executions>
                    <execution>
                        <id>migrate-database</id>
                        <phase>pre-integration-test</phase>
                        <goals>
                            <goal>migrate</goal>
                        </goals>
                        <configuration>
                            <driver>net.sourceforge.jtds.jdbc.Driver</driver>
                            <table>MIGRATION_LOG</table>
                            <sqlMigrationPrefix>ALL_</sqlMigrationPrefix>
                            <skip>false</skip>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>
</profile>