mybatiplus的apply_mybatis升级为mybatis-plus踩到的坑

在将mybatiplus的apply_mybatis升级到mybatis-plus时遇到Invalid bound statement异常,问题根源在于SqlSessionFactory的配置。解决方案包括替换SqlSessionFactoryBean为MybatisSqlSessionFactoryBean或者移除项目中自定义的sqlSessionFactory,让mybatis-plus自动注入。
摘要由CSDN通过智能技术生成

Invalid bound statement (not found): com.lybgeek.admin.file.mapper.FileMapper.insert

查看FileMapper.xml配置,确实没有发现绑定insert这个sql语句块。那是否加上insert的sql语句块,可以解决问题?加上确实是能解决问题。

但如果用过mybatis-plus的朋友,应该会知道,mybatis-plus中BaseMapper已经帮我们封装好了一部分的单表增删改查,我们无需写配置,就可以实现单表增删改改查。。在xml配置insert是治标不治本。

那要如何排查呢?

方向一:是否是包冲突引起?

利用maven helper插件包冲突

从图可以抛光不是包冲突引起的。

注:因为之前吃过包冲突的亏,因此在把若依的orm改成mybatis-plus之前,就已经去除跟mybatis相关的jar冲突了

方向二:是不是约会不同类包的BaseMapper

我们约会的必须是

而不是

不过出现这个问题,通常也是约会不同版本的mybatis-plus jar才会出现。如果你是只用3+以上版本,他约会就只有

方向三:通用方法(断点调试)

其实代码排查最怕就是异常栈被吃了,如果有异常信息,排查方向相对比较好找。诸如这个异常,其异常栈信息为

我们从异常栈信息,我们可以知道这个异常从

这个类抛出,于是我们可以把断点先设置到这边。通过原始码我们可以知道org.apache.ibatis.mapping.MappedStatement空了,导致报了如上上异常,而MappedStatement又是由

提供。而配置是通过

进行设置。然后继续排查,就会发现

这个自动装配类。里面有这么一段代码

// TODO 对源码做了一定的修改(因为源码适配了老旧的mybatis版本,但我们不需要适配)Class extends LanguageDriver> defaultLanguageDriver = this.properties.getDefaultingLanguageDriver;if(!ObjectUtils.isEmpty( this.languageDrivers)) {factory.setingLanguageDrivers( this.languageDrivers);}Optional.ofNullable(defaultLanguageDriver).ifPresent(factory::setDefaultingLanguageDriver);

// TODO 自定义枚举包if(StringUtils.hasLength( this.properties.getTypeEnumsPackage)) {factory.setTypeEnumsPackage( this.properties.getTypeEnumsPackage);}// TODO 此处必为非 NULLGlobalConfig globalConfig = this.properties.getGlobalConfig;// TODO 注入填充器this.getBeanThen(MetaObjectHandler. class, globalConfig::setMetaObjectHandler);// TODO 注入主键生成器this.getBeanThen(IKeyGenerator. class, i -> globalConfig.getDbConfig.setKeyGenerator(i));// TODO 注入sql注入器this.getBeanThen(ISqlInjector. class, globalConfig::setSqlInjector);// TODO 注入ID生成器this.getBeanThen(IdentifierGenerator. class, globalConfig::setIdentifierGenerator);// TODO 设置 GlobalConfig 到 MybatisSqlSessionFactoryBeanfactory.setGlobalConfig(globalConfig);returnfactory.getObject;}

作者在注释上都写了,要用

这样查看若依代码,发现在若依中的mybatis配置类中有配置如下代码片段

final SqlSessionFactoryBean sessionFactory = newSqlSessionFactoryBean;sessionFactory.setDataSource(dataSource);sessionFactory.setTypeAliasesPackage(typeAliasesPackage);sessionFactory.setMapperLocations( newPathMatchingResourcePatternResolver.getResources(mapperLocations));sessionFactory.setConfigLocation( newDefaultResourceLoader.getResource(configLocation));returnsessionFactory.getObject;}

mybatis-plus将不会自动帮我们注入SqlSessionFactory,而使用我们自己定义的SqlSessionFactory。而若依项目配置的SqlSessionFactory不是MybatisSqlSessionFactoryBean

修复

1,方法一

把mybatis的SqlSessionFactoryBean替换成mybatis-plus的MybatisSqlSessionFactoryBean

2,方法二

去掉项目中sqlSessionFactory。这样mybatis-plus就会自动帮我们注入sqlSessionFactory

总结

确实是一个挺好的方法,但有时可能搜索半天都没找到答案,我们就可以通过异常信息栈,以及调试线程栈,就可以得到一些比较有用的信息。出现异常并不可怕,可怕的是出了问题,异常日志信息被吞噬,都不知道从何排查。最后安利一下若依这个脚手架,管理后台开发神器,谁用谁知道

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值