繁体   English   中英

如何在JPA中使用动态JNDI数据源?

[英]how can I use my dynamic JNDI datasources with JPA?

我们有一个应用程序,它使用多个数据库来存储不同国家/地区的相同数据。

例如, Subscription对象可能与德国或西班牙相关联。 如果是德语订阅,则需要将其存储在与西班牙语订阅不同的数据库中。 数据库在结构上是相同的,但它们具有不同的内容。

我们在jboss 5上运行,并且每个文件都有一个不同的数据源配置(* ds.xml)文件,在启动时动态生成。 它们存储在JNDI中 - 所以我们有DataSourceDE,DataSourceES等。

以下是它应该如何工作:如果请求进入'为德国提取订阅17'那么我计算数据源应该是DataSourceDE并使用JPA / hibernate从正确的数据库中获取该对象。 西班牙语数据库中也会有一个订阅17,在这个例子中我不想要。

我可以自动生成persistence.xml以为数据源创建额外的持久性单元,但是Subscription类使用以下注释进行注释:

@PersistenceContext(unitName="core")

这不起作用 - 如何动态地在java对象上设置持久化上下文?

您想要实现的目标称为多租户 这是一个非常适合您的问题的教程,使其工作。

主要思想是使用一个Stateless会话bean ,它引用了两个持久性单元。 根据必须完成的操作,此bean执行查找以调用相应的EntityManager 此外:

多租户使用EJB 3.1和JPA 2.0

您可以在运行时更改EntityManager的持久性上下文,如下所示:

EntityManagerFactory emf = 
    Persistence.createEntityManagerFactory(persistenceUnitName);
EntityManager em = emf.createEntityManager();

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM