报错:Invalid bound statement (not found): com.pinyougou.mapper.TbBrandMapper.selectByExample

本文介绍了一个在IDEA项目中遇到的关于MyBatis无法找到resources目录下Mapper XML文件的问题及解决方案。问题在于创建包结构时的方式导致路径不正确,通过调整包的创建方式,确保资源文件能够被正确识别。

在这里插入图片描述
报错:Invalid bound statement (not found): com.pinyougou.mapper.TbBrandMapper.selectByExample

我的项目是用idea写的。错误提示没有扫到resources下的mapper.xml文件。

项目代码没问题,后来发现问题出在“包名”上
在创建resources下包的时候,由于idea是创建Directory,
在这里插入图片描述
这样创包则会创一个名为“com.mapper.service”的包,而不是com包下还有一个“mapper”的包。

对比如下:

在这里插入图片描述
在这里插入图片描述
应在resources下先创“com”包,再创“mapper”包,接着是“mapper”包以及包下的各种“XXMapper.xml”。

这样就完美解决了!!

当你在使用Maven集成MyBatis-Plus时遇到这个错误,它通常意味着MyBatis无法找到你指定的Mapper接口的映射方法。在这个例子中,`com.hlw.yx.mapper.GasClientMapper.getinfo`是一个无效的bound statement,也就是找不到对应的SQL语句。 解决这个问题的步骤包括: 1. **检查Mapper接口**:确认`GasClientMapper`接口是否存在,并且其中是否有一个名为`getinfo`的方法。如果方法名拼写错误、大小写不符或者注解配置有误,MyBatis都不会识别。 ```java // 示例Mapper接口 public interface GasClientMapper { ResultInfo getinfo(@Param("id") Long id); // 确保方法名和参数匹配 } ``` 2. **Mapper XML配置文件**:在`src/main/resources/mapper`目录下的相应XML文件(例如`GasClientMapper.xml`)中,确认`getinfo`方法是否有正确的映射配置。比如,如果有动态SQL,需要确保SQL语句语法正确。 ```xml <mapper namespace="com.hlw.yx.mapper.GasClientMapper"> <select id="getinfo" resultType="com.example.ResultInfo"> SELECT * FROM table_name WHERE id = #{id} </select> </mapper> ``` 3. **路径和命名空间**:检查Mapper的namespace是否与实际包名一致。如果Mapper的位置或名称改变,记得更新Mapper XML的namespace属性。 4. **别名或者全限定名**:确认你在代码中引用Mapper时使用的全限定名是否正确,有时候可能会因为工程结构更改而引入了混淆。 5. **重启项目**:有时候可能是缓存的问题,尝试清理Maven项目的本地仓库并重新构建。 如果你已经检查过以上所有地方还是出现问题,可能需要查看具体的错误堆栈信息来获取更详细的错误原因。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值