Invalid bound statement (not found)的原因以及解决方法
·
相信我们在学习Mybatis的时候都出现过 Invalid bound statement (not found) 这个错误,一般由以下几种可能导致这个错误
一:mapper方法名 和 mapper.xml id名不对应
例如:
mapper:

对应的mapper.xml

这里建议小伙伴们下载一个插件,方便查看你的xml是否对应了你想对应的mapper接口

有了这个插件,你的接口mapper和对应的mapper.xml都会有小鸟,点一下就会 ‘飞到’ 对应的接口(或者xml)

二、 mapper.xml的namespace是不是写错了

这里的 namespace要写所需实现的接口的全限定性类名
三、是不是xml文件没有编译
打开target看看有没有xml文件在里面

没有的话就需要在pom.xml里面配置一下resource
<!-- 如果不添加此节点src/main/java目录下的所有配置文件都会被漏掉。 -->
<resources>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.xml</include>
</includes>
</resource>
<resource>
<directory>src/main/resources</directory>
<includes>
<include>**/*.xml</include>
<include>**/*.properties</include>
<include>**/*.ini</include>
</includes>
</resource>
</resources>
效果如下:
四、是不是resources的路径问题
主要,如果想吧mapper.xml文件写在resources下的话,新建的包要用 “ / ” 分开 而不是用 “ . ”
如:com/zhp/mapper 这个是正确的 com.zhp.mapper是错误的
如下:
查看一下包名对不对: 

一定得是这样的嵌套的,以下是错误示例:(创建时候用错误的用 . 而不是 / )

还有,这个resources里的这个mapper包一定和src一样,以免出现不必要的错误
AtomGit 是由开放原子开源基金会联合 CSDN 等生态伙伴共同推出的新一代开源与人工智能协作平台。平台坚持“开放、中立、公益”的理念,把代码托管、模型共享、数据集托管、智能体开发体验和算力服务整合在一起,为开发者提供从开发、训练到部署的一站式体验。
更多推荐


所有评论(0)