解决使用mybatis-plus报错Invalid bound statement (not found)错误

这个问题昨晚花了很长时间去查资料,其实网上的方法已有很多,但都解决不了。于是从spring初始化mybatis开始看起,发现程序不是没有扫描到mybatis-plus配置,而是压根没有去扫描。为什么呢?

因为:SessionFactoryBean是自定义的,不是spring自动注入的!

然后又会有个问题,不是有@MapperScan么?怎么就没扫描xml文件呢?通过断点发现,mybatis-locations这个匹配是由sessionFactoryBean去配置的,@MapperScan扫描的时候,会扫描mapper类包,然后从sessionFactoryBean中取xml的匹配,然而,自定义的SqlSession并没有去设置mybatisLocation这个参数,这时候就会当没xml文件处理。在执行方法的时候,mybatis需要去找statement,当然就找不到了。

所以解决问题的办法也很简单,有三种解决方式

1. 用自动注入的sessionFactoryBean

2. 手动设置sessionFactoryBean.setMybatisLocation : new PathMatchingResourcePatternResolver().getResources(“classpath*:/mapper/*.xml”)

3.把xml文件放到mapper同级目录下,这个参考代码,当没有设置xml路径时,会在当前类的同级路径下去找xml文件,这样找到也可以。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值