我目前有两个不同的数据库:Oracle和DB2。我正在尝试使用用于liquibase的maven插件在这两个数据库上运行两个不同的变更日志。
到目前为止,我有:
在我的配置中,我同时设置了Oracle和DB2连接:
<configuration>
<changeLogFile>src/main/resources/liquibase/changelogORACLE.xml</changeLogFile>
<driver>oracle.jdbc.OracleDriver</driver>
<url>jdbc:oracle:thin:@vdfdfseisfs3:3131:orcl</url>
<username>liquibase</username>
<password>password</password>
<changeLogFile>src/main/resources/liquibase/changelogDB2.xml</changeLogFile>
<driver>com.ibm.db2.jcc.DB2Driver</driver>
<url>jdbc:db2://111.111.1.11:10000/test</url>
<username>Admini</username>
<password>password</password>
</configuration>
在执行过程中,我的设置如下:
<execution>
<phase>process-resources</phase>
<goals>
<goal>update</goal>
</goals>
</execution>
而且我都设置了依赖项:
<dependency>
<groupId>com.oracle</groupId>
<artifactId>ojdbc6</artifactId>
<version>11.2.0</version>
</dependency>
<dependency>
<artifactId>com.ibm.db2.jcc</artifactId>
<groupId>db2jcc</groupId>
<version>4.9.78</version>
<scope>system</scope>
<systemPath>${basedir}/my-repo/com/ibm/db2/jcc/db2jcc/4.9.78/db2jcc-4.9.78.jar</systemPath>
</dependency>
我的问题是,当我从WindowsCMD
像这样运行时:mvn liquibase:update
仅将执行DB2更改日志,因此我将为DB2数据库创建数据,但不会为Oracle创建数据。为什么只有一个变更日志文件被执行?
我可以单独执行Oracle和DB2更改日志,但是我想一起执行它们。
Liquibase maven插件很可能不允许在pom的此部分中进行两种配置:
<configuration>
<changeLogFile>src/main/resources/liquibase/changelogORACLE.xml</changeLogFile>
<driver>oracle.jdbc.OracleDriver</driver>
<url>jdbc:oracle:thin:@vdfdfseisfs3:3131:orcl</url>
<username>liquibase</username>
<password>password</password>
<changeLogFile>src/main/resources/liquibase/changelogDB2.xml</changeLogFile>
<driver>com.ibm.db2.jcc.DB2Driver</driver>
<url>jdbc:db2://111.111.1.11:10000/test</url>
<username>Admini</username>
<password>password</password>
</configuration>
它可能只读第一个。通过阅读Maven生命周期文档,您似乎可以通过使用两个不同的执行来执行所需的操作,但是我不清楚您如何更改pom以使两个执行使用两种不同的配置。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句