java – 使用多个数据源时Spring中的多个实体管理器问题
发布时间:2020-12-15 01:42:11 所属栏目:大数据 来源:网络整理
导读:我的applicationContext.xml中有两个实体管理器,它们对应两个不同的数据库.我可以使用entityManager1轻松查询database1,但是当我尝试使用entityManager2访问database2时,我没有得到任何结果.我正在使用Spring Hibernate JPA. 这是我的ApplicationContext.xml
我的applicationContext.xml中有两个实体管理器,它们对应两个不同的数据库.我可以使用entityManager1轻松查询database1,但是当我尝试使用entityManager2访问database2时,我没有得到任何结果.我正在使用Spring Hibernate JPA. 这是我的ApplicationContext.xml
这是我的服务层代码,可以与enityManager1一起使用:
我的两个persitence.xml文件如下所示:
和
如果我更改了我的服务层(如下所示),我没有得到任何结果.基本上列表的大小为零:
所以基本上你可以看到我有两个具有完全相同结构的实体(状态),为了区分彼此,我将它们放入单独的包中 根据我的知识,我在这里没有做任何疯狂的事情,但它似乎仍然无法正常工作.这个问题是怎么造成的,怎么解决这个问题? 后续行动:我忘记提到的一件事是即使有两个不同的数据库,但数据库服务器名称相同.我不知道这是否是一个有用的信息.所以想到分享它. 这是我现在得到的例外:
最佳答案
我遇到了同样的问题,但是有多个Hibernate会话工厂:2个具有相同结构的DB,我不想拥有2个相同的DAO集等等.虽然我的经验是Hibernate,但我怀疑你可以使用相同的解决方案:Spring的AbstractRoutingDataSource.它允许您配置应用程序,以便在运行时根据ThreadLocal上设置的值确定要使用的数据源.有关介绍,请参见http://blog.springsource.com/2007/01/23/dynamic-datasource-routing/.最终发生的事情是,工厂中的dataSource引用不会指向硬编码的dataSource bean,而是指向AbstractRoutingDataSource.要设置每个线程的切换,请使用@Aspect确定要命中的数据库.
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |