我正在开发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,here和here的建议修补程序无效。
我有一个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上,并且因此回滚了事务。我认为可以有更清晰的解决方案,但作为一个快速解决方案,它工作正常
答案 0 :(得分:1)
试试这个:
<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>