![](/img/trans.png)
[英]How can I configure JPA repositories for different DataSources in SpringBoot?
[英]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
。 此外:
您可以在运行时更改EntityManager的持久性上下文,如下所示:
EntityManagerFactory emf =
Persistence.createEntityManagerFactory(persistenceUnitName);
EntityManager em = emf.createEntityManager();
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.