org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)

这个问题是:mapper.xml文件和mapper.java文件对应不上

情景:springboot项目,需要自定义SQL语句。其中有mapper.java, mapper.xml,dao.java
说明:mapper.java interface
           mapper.xml和mapper.java相映射。
           dao数据访问层。

访问逻辑  通过访问dao->mapper.java->mapper.xml

我的mapper.java 在src/main/java   mapper.xml在resources下   两者路径不相同
当访问写在xml里面的自定义sql语句时,出现了org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)。
 

查网上有几种解决方案:

1:检查xml文件所在的package名称是否和interface对应的package名称一一对应

2:检查xml文件的namespace是否和xml文件的package名称一一对应

3:检查函数名称能否对应上

4:去掉xml文件中的中文注释

5:随意在xml文件中加一个空格或者空行然后保存

因为我的这一系列文件  对象model,mapper.java, mapper.xml  都是使用mybatis-generator自动生成的,所以基本上上面的5种都不能解决。并且我也通过事实证明了,确实没有解决。

继续查询,发现就是因为我的mapper.xml文件和mapper.java文件的目录不一样,而默认是一样的,所以必须重新说明。

ResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();
sqlSessionFactory.setMapperLocations(resolver.getResources("classpath*:mappers/*.xml"));

详细解决方案:
创建MybatisConfig.java文件

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值