gpt4 book ai didi

java - 如何配置 spring 使用两个不同的数据源。获取 PlatformTransactionManager 错误的 NoUniqueBeanDefinitionException

转载 作者:行者123 更新时间:2023-12-02 11:07:32 26 4
gpt4 key购买 nike

我正在开发 Spring Boot 应用程序,该应用程序已经在其 applicationContext.xml 文件中建立了数据库连接以及必要的事务管理器和供应商等。

我现在需要将应用程序连接到第二个数据库。但我对此有疑问。在我的单元测试中,连接很好,可以进行简单的查询来检索数据,这就是我需要它做的一切。但是,当我将应用程序编译成 jar 并运行它时,出现以下错误

NoUniqueBeanDefinitionException: No qualifying bean of type "org.springframework.transaction.PlatformTransactionManager" available: expected single matching bean but found 2: transactionManager, transactionManager2

我花了很长时间寻找如何解决这个问题,以及我找到的建议修复here , herehere没有工作过。

我有一个 persistence.xml,其中定义了两个持久单元。在我的 applicaitonContext.xml 中,我定义了两个数据源、两个事务管理器和两个实体管理器工厂。然后,我使用 @persitsencecontext 和 @Transactional("") 注释来说明要使用哪个持久单元和管理器,但我仍然收到错误。我还在 <qualifier> 中添加了标记到应用程序上下文文件,因为我将此视为使用 @transactional 注释的建议修复,但仍然没有运气。

我的代码如下,任何人都可以发现我犯的错误,以及为什么它可能无法按预期工作

applicationContext.xml

<bean id="dataSource1" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="org.hsqldb.jdbcDriver"/>
<property name="url" value="..."/>
<property name="username" value="..."/>
<property name="password" value="..."/>
</bean>


<bean id="entityManagerFactory" name="proxy">
<property name="persistenceUnitName" value="proxy" />
<property name="persistenceUnitXmlLocation" value="classpath:META-INF/persistence.xml" />
<property name="dataSource" ref="dataSource1" />
<property name="jpaVendorAdapter" ref="hiberanteVendorAdapter" />
<property name="jpaProperties">
<props>
<prop key="hiberante.hbm2ddl.auto">valudate</prop>
</props>
</property>
</bean>

<bean id="hibernateVendorAdapter" class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
<property name="databasePlatform" value="org.hibernate.dialect.HSQLDialect" />
<property name="database" value="HSQL" />
<property name="showSql" value="true" />
</bean>

<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
<property name="entityManagerFactory" ref="entityManagerFactory" />
<qualifier value="transactionManager1" />
</bean>



<!-- Second datasource -->
<bean id="dataSource2" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="org.hsqldb.jdbcDriver"/>
<property name="url" value="..."/>
<property name="username" value="..."/>
<property name="password" value="..."/>
</bean>

<bean id="entityManagerFactory2" name="proxy">
<property name="persistenceUnitName" value="proxy2" />
<property name="persistenceUnitXmlLocation" value="classpath:META-INF/persistence.xml" />
<property name="dataSource" ref="dataSource2" />
<property name="jpaVendorAdapter" ref="hiberanteVendorAdapter2" />
<property name="jpaProperties">
<props>
<prop key="hiberante.hbm2ddl.auto">valudate</prop>
</props>
</property>
</bean>


<bean id="transactionManager2" class="org.springframework.orm.jpa.JpaTransactionManager">
<property name="entityManagerFactory" ref="entityManagerFactory2" />
<qualifier value="transactionManager2" />
</bean>

<bean id="hibernateVendorAdapter2" class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter" />


<tx:annotation-driven/>

实现

@Repository
@Transactional("transactionManager2")
public class myDaoImpl extends GenericJPADao<Integer, Integer> implements ImyDao {

@PersistenceContext(unitName="proxy2")
protected EntityManager em;


}

解决方案

接受的答案对我来说是正确的解决方案,但有一些事情需要注意。这些bean 必须指向它们各自的entityManagerFactory,并且您需要小心设置autowire-candidate="false" 的bean。上,因为我一开始将其设置为错误的,结果导致事务回滚。我认为可以有更干净的解决方案,但作为快速修复它效果很好

最佳答案

试试这个:

<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager" autowire-candidate="false">
<property name="entityManagerFactory" ref="entityManagerFactory" />
</bean>


<bean id="transactionManager2" class="org.springframework.orm.jpa.JpaTransactionManager">
<property name="entityManagerFactory" ref="entityManagerFactory" />
</bean>

关于java - 如何配置 spring 使用两个不同的数据源。获取 PlatformTransactionManager 错误的 NoUniqueBeanDefinitionException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50854592/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com