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

时间:2015-01-29 20:15:55

标签: java hibernate tomcat persistence

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

我需要能够切换jdbc.url,具体取决于系统环境变量(或可能的其他标志)。最后,我希望能够部署指向两个不同数据库的webapp的 staging production 版本。但是,目前,我必须实际更改jdbc.url中的persistence.xml值,并在配置之间切换时重新保存。

我当前的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()作为选项的信息,但我找不到任何关于如何实现此问题的简洁示例。我之前已经解决过这个问题,但我找不到干净的教程或建议。

如何在不必每次都重写persistence.xml文件的情况下使用Hibernate交换机数据库配置?

非常感谢!

1 个答案:

答案 0 :(得分:0)

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

使用maven作为构建工具,您可以在构建时基于maven配置文件替换属性 - 通过maven资源插件中的过滤

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