spring+mybatis多数据源(No unique bean of type [org.apache.ibatis.session.SqlSession)

在项目中使用mybatis与spring进行开发的时候,由于使用到多数据源,在进行依赖注入的时候发生如下异常。

Caused by:
org.springframework.beans.factory.BeanCreationException: 
Could not autowire method: 
public final void org.mybatis.spring.support.
SqlSessionDaoSupport.setSqlSessionFactory
(org.apache.ibatis.session.SqlSessionFactory); 
nested exception is org.springframework.beans.factory.
NoSuchBeanDefinitionException: 
No unique bean of type [org.apache.ibatis.session.SqlSessionFactory] is defined: 
expected single matching bean but found 2: [sqlSessionFactory1, sqlSessionFactory2]

 

主要是项目中一个数据源的Dao处理以及上层使用的注解方式,而另一个数据源全部是通过配置文件来处理的。
后来发现是自动扫描出现的问题,将自动扫描代码的annotation-config设置为false,如下所示:

<context:component-scan base-package="com.xxx.xxx"
		annotation-config="false" />

 以上情况是dao代码中均使用org.mybatis.spring.SqlSessionFactoryBean配置造成的。

如果dao代码中使用SqlSessionTemplate,则不需要调整上面所述的自动注解的问题,代码如下:

<bean id="sqlSessionTemplate1" 
           class="org.mybatis.spring.SqlSessionTemplate">
           <constructor-arg index="0" ref="cspSqlSessionFactory" />
</bean>

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值