Java - Hibernate 可以在 persistence.xml 中的两种数据库配置之间进行选择吗?

Java - Can Hibernate choose between two database configurations in persistence.xml?

我在 Tomcat 7.0 上有一个 Java 应用程序 运行 Hibernate管理数据库。

我需要能够根据系统环境变量(或可能的其他标志)切换 jdbc.url。最终,我希望能够部署指向两个不同数据库的 Web 应用程序的 stagingproduction 版本。但是,目前,我必须物理更改 persistence.xml 中的 jdbc.url 值,并在配置之间切换时重新保存它。

我当前的 persistence.xml 文件是:

<persistence xmlns="http://java.sun.com/xml/ns/persistence"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
             version="2.0">

    <persistence-unit name="my_pu" transaction-type="RESOURCE_LOCAL">
        <provider>org.hibernate.ejb.HibernatePersistence</provider>
        <shared-cache-mode>ALL</shared-cache-mode>
        <properties>
            <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver" />
            <property name="javax.persistence.jdbc.url" value="jdbc:mysql://my.rds.url.goes.here/mydatabase" />
            <property name="javax.persistence.jdbc.user" value="myusername" />
            <property name="javax.persistence.jdbc.password" value="mypassword" />
            <property name="connection.provider_class" value="org.hibernate.connection.C3P0ConnectionProvider"/>
        </properties>
    </persistence-unit>

</persistence>

我读过有关使用 createEntityManagerFactory() 作为选项的信息,但我找不到任何清晰的示例来说明如何实现它。我确定这个问题以前已经处理过,但我找不到干净的教程或建议。

如何让我的 Hibernate 切换数据库配置而不必每次都重写 persistence.xml 文件?

如果您在项目中使用 spring 或 maven,有几种方法可以做到:

使用 maven 作为构建工具,您可以在构建期间根据 maven 配置文件替换属性 - 通过在 maven 资源插件中进行过滤

如果您在项目中使用 spring,PropertyPlaceholderConfigurer 可以为您注入值。它可以将值作为 jvm 参数或从 属性 文件中读取。这些 属性 文件可以放在 tomcat/conf 目录中,这样每个 tomcat 都知道自己的配置,或者您可以构建所有可能的属性,select 它们基于 spring个人资料