动态JPA连接

wob*_*ogs 9 java jpa multiple-databases

我有一个相当标准的Java EE6 Web应用程序使用JPA 2,依赖注入连接到MySQL数据库,一切正常.我现在要做的是让这个应用程序与我们在客户端站点安装的其他应用程序的数据库进行交互 - 基本上作为我们其他应用程序安装的单一控制点.

我正在努力的是如何最好地与其他数据库进行交互.理想情况下,我想为每次安装创建一个EntityManager并使用JPA进行交互,但我看不出任何设置方法.例如,我可能有一个应用程序类型的5个安装(以及数据库),并且主控制应用程序在运行时之前不会知道其他安装.这似乎排除了使用EntityManager的依赖注入和所有自动事务demacation等等.替代选项是只创建一个DataSource并手动进行交互.虽然灵活,但这显然需要更多的努力.

所以,我的问题是如何最好地解决这个问题?

Ama*_*icA 5

我也在研究这个问题,到目前为止,我发现以下博客文章描述了一种方法来做到这一点 http://ayushsuman.blogspot.com/2010/06/configure-jpa-during-run-time-dynamic .html:

从persistance.xml中删除了所有数据库属性

<persistence>
<persistence-unit name="jpablogPUnit" transaction-type="RESOURCE_LOCAL">
<class>com.suman.Company</class>
</persistence-unit>
</persistence>
Run Code Online (Sandbox Code Playgroud)

更改了您在配置entityManager的java文件,在我们的示例中为TestApplication.java

package com.suman;

import java.util.HashMap;
import java.util.Map;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import org.apache.log4j.Logger;

/**
* @author Binod Suman
*/
public class TestApplication {

Logger log = Logger.getLogger(TestApplication.class);
public static void main(String[] args) {
TestApplication test = new TestApplication();
test.saveCompany();
}

public void saveCompany(){
log.info("Company data is going to save");
EntityManagerFactory emf;
Map properties = new HashMap();
properties.put("hibernate.connection.driver_class", "com.mysql.jdbc.Driver");
properties.put("hibernate.connection.url", "jdbc:mysql://localhost:3306/sumandb");
properties.put("hibernate.connection.username", "root");
properties.put("hibernate.connection.password", "mysql");
properties.put("hibernate.dialect", "org.hibernate.dialect.MySQLDialect");
properties.put("hibernate.show-sql", "true");
//emf = Persistence.createEntityManagerFactory("jpablogPUnit");
emf = Persistence.createEntityManagerFactory("jpablogPUnit",properties);
EntityManager entityManager = (EntityManager) emf.createEntityManager();
entityManager.getTransaction().begin();
Company company = new Company(120,"TecnoTree","Espoo, Finland");
entityManager.persist(company);
entityManager.getTransaction().commit();
log.info("Company data has been saved");
}

}
Run Code Online (Sandbox Code Playgroud)