spring boot 因mybatis版本引发的问题

使用spring boot整合项目的时候,遇到了一个异常,如下:

2018-06-03 20:44:17.660  WARN 301924 --- 
[           main] o.s.b.f.s.DefaultListableBeanFactory     :
Bean creation exception on non-lazy FactoryBean type check: org.springframework.beans.factory.UnsatisfiedDependencyException: 
Error creating bean with name 'roleDao' defined in file
[B:\workspace_spring\resume\baseservice\target\classes\com\ma\base\dao\RoleDao.class]: 
Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; 
nested exception is 
Error creating bean with name 'sqlSessionFactory' defined in 
class path resource
[org/mybatis/spring/boot/autoconfigure/MybatisAutoConfiguration.class]: 
 org.springframework.beans.BeanInstantiationException: 
Factory method 'sqlSessionFactory' threw exception;
 nested exception is java.lang.NoSuchMethodError: 
 org.mybatis.spring.SqlSessionFactoryBean.setVfs(Ljava/lang/Class;)V

根据异常信息,MybatisAutoConfiguration类中出现了方法调用异常,打开源码查看

  @Bean
  @ConditionalOnMissingBean
  public SqlSessionFactory sqlSessionFactory(DataSource dataSource) throws Exception {
    SqlSessionFactoryBean factory = new SqlSessionFactoryBean();
    factory.setDataSource(dataSource);
    factory.setVfs(SpringBootVFS.class);

发现 factory.setVfs(SpringBootVFS.class)在SqlSessionFactoryBean类中不存在,导致sqlsesessionFactory创建失败。纠结了很久,找了很多资料,查看spring boot版本,又看了mybatis-spring-boot-starter整合包的版本,都没有问题的,为什么我的项目启动就遇到了这种问题呢!!!无奈之下,对比了之前的项目和现在项目结构的maven引入jar包结构,我坑。。。结果居然是在父工程中定义了这个依赖

<dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis-spring</artifactId>
    <version>1.2.2</version>
</dependency>

坑爹…原来就是在父工程中这里搞得鬼,去掉后,在此查看maven引入的版本mybatis-spring-1.3.1,OK。万事大吉,启动正常。

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值