【问题标题】:Java - Can Hibernate choose between two database configurations in persistence.xml?Java - Hibernate 可以在persistence.xml 中的两个数据库配置之间进行选择吗?
【发布时间】:2024-04-28 12:10:05
【问题描述】:

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

我需要能够根据系统环境变量(或可能的其他标志)切换jdbc.url。最终,我希望能够部署我的 webapp 的 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 文件?

【问题讨论】:

  • 创建两个持久化单元。

标签: java hibernate tomcat persistence


【解决方案1】:

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

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

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

【讨论】:

    最近更新 更多