我正在开发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


我花了很长时间寻找如何解决此问题,而我发现的hereherehere的建议修复没有用。

我有一个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>

10-08 08:34
查看更多