Java - Hibernate 可以在 persistence.xml 中的两种数据库配置之间进行选择吗?
Java - Can Hibernate choose between two database configurations in persistence.xml?
我在 Tomcat 7.0 上有一个 Java 应用程序 运行 Hibernate管理数据库。
我需要能够根据系统环境变量(或可能的其他标志)切换 jdbc.url
。最终,我希望能够部署指向两个不同数据库的 Web 应用程序的 staging 和 production 版本。但是,目前,我必须物理更改 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个人资料
我在 Tomcat 7.0 上有一个 Java 应用程序 运行 Hibernate管理数据库。
我需要能够根据系统环境变量(或可能的其他标志)切换 jdbc.url
。最终,我希望能够部署指向两个不同数据库的 Web 应用程序的 staging 和 production 版本。但是,目前,我必须物理更改 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个人资料