Invalid bound statement (not found)常见

这个报错的本质就是你写的mapper接口找不到对应的xml,而产生这一点的可能性有很多

1.xml里面的namespace不对

2.或者xml里面的id和mapper(namespace对应的文件)里面的方法名不一样

这里说一下因为idea搜索默认大小写的不敏感原因,有时候怎么搜索都是一样的,这个时候可以想想是不是大小写的原因,这里推荐在搜索的时候点亮箭头的图标,搜索出来的就是大小写敏感的(坑 曾经遇到过 一度让我怀疑人生)

3.parameterType对应不上

4.mapperScan的扫描路径没配置对

 

5.mapper写在了java目录里面

看到感觉挺有意思的,涉及maven编译的一些原理,直接附上原文

Invalid bound statement (not found): 各种原因_一颗小小的石头.的博客-CSDN博客_invalid statement

6.mapper-locations的配置问题

 这是我在项目中遇到的,发现项目写了两套sql脚本针对不同数据库,而我改的那套刚好是没有扫描的

7.配置加载顺序问题

这里记录几个实验下来发现的现象

在idea里面配置两个相同的属性,在编译器是会红色提示的,但实际上并不影响启动

 

同一个文件两个相同的配置,生效的是后一个配置(不同配置文件是外层的覆盖前面的)

下图中生效的是mapper/*.xml

 

 

location的配置写法有两种mybatis.mapperLocations和mybatis.mapper-locations,无论顺序如何生效的都是mybatis.mapper-locations

下图中生效的是mapper/*.xml

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值