我想根据所选的 Maven 配置文件使用两个不同的数据库。对于“生产”配置文件,我想使用 MySQL 数据库,而对于“开发”配置文件,我想使用内存中的 HSQLDB。
我发现可以有两个 persistence.xml 文件。一个在“src/main/resources/META-INF”中,另一个存储在“src/test/resources/META-INF”中。这使得选择不同的数据库进行测试成为可能。
但是是否也可以根据所选的 Maven 配置文件进行数据库选择?
我想根据所选的 Maven 配置文件使用两个不同的数据库。对于“生产”配置文件,我想使用 MySQL 数据库,而对于“开发”配置文件,我想使用内存中的 HSQLDB。
我发现可以有两个 persistence.xml 文件。一个在“src/main/resources/META-INF”中,另一个存储在“src/test/resources/META-INF”中。这使得选择不同的数据库进行测试成为可能。
但是是否也可以根据所选的 Maven 配置文件进行数据库选择?
这是可能的,尽管不改变persistence.xml
:
我们为此使用 Maven 配置文件和资源过滤。您将需要persistence.xml
在您的.properties
文件或.pom
.
在构建期间,您指定配置文件,maven 将用您的属性替换占位符。
我们已经使用这种技术在不同的部署环境之间切换数据源。您还可以使用它来切换 PU 或其他属性。
首先,为资源过滤定义配置文件:
<profiles>
<profile>
<id>set_datasource</id>
<build>
<!-- enable resource filter to set the datasource name -->
<resources>
<resource>
<directory>src/main/resources</directory>
<filtering>true</filtering>
...
为每个数据源创建一个配置文件:
<profile>
<id>db_test</id>
<properties>
<database.name>test_ds</database.name>
</properties>
</profile>
在您的持久性单元中,准备占位符
<persistence-unit name="my_db">
<jta-data-source>java:jboss/datasources/${datasource.name}</jta-data-source>
</persistence-unit>
使用两个配置文件调用 maven:
mvn test -Pset_datasource,db_test
请注意,我们主要将其用于 UI 和用户测试。对于集成/功能测试,我们使用Arquillian。对于 Arquillian,您可以定义一个单独的persistence.xml
文件,甚至可以即时创建一个。