org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.cmft.mapper.asset.stock.AmcAssetStockMapper.fundAssetCount at org.apache.ibatis.binding.MapperMethod$SqlCommand.<init>(MapperMethod.java:235) at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.<init>(MybatisMapperMethod.java:49)
时间: 2023-07-17 20:00:34 浏览: 59
这个异常通常表示在MyBatis框架中找不到指定的SQL语句。根据你提供的错误信息,可以看出出现了`Invalid bound statement (not found)`的错误,具体指的是`com.cmft.mapper.asset.stock.AmcAssetStockMapper.fundAssetCount`语句未找到。
可能的原因和解决方法如下:
1. 检查Mapper接口路径和命名空间:确保`com.cmft.mapper.asset.stock.AmcAssetStockMapper`路径正确,并且在对应的XML配置文件中定义了相应的命名空间。
2. 检查Mapper接口方法名:确认在`AmcAssetStockMapper`接口中存在名为`fundAssetCount`的方法,并且该方法使用了正确的注解(`@Select`、`@Update`等)来标识对应的SQL语句。
3. 检查XML配置文件:在对应的XML配置文件(通常是Mapper接口名加上`.xml`后缀)中,确保存在与方法名`fundAssetCount`相匹配的SQL语句定义。
4. 检查SQL语句的ID:确认XML配置文件中定义的SQL语句ID与Mapper接口方法中使用的SQL语句ID一致。可能存在拼写错误或大小写不匹配等问题。
如果以上步骤都正确无误,仍然出现该异常,可以尝试使用日志输出功能来查看更详细的错误信息,以便更好地定位问题。
相关问题
SpringBooot org.apache.ibatis.binding.BindingException: Invalid bound statement (not found):
在Spring Boot中,当出现"org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)"异常时,通常是因为MyBatis无法找到对应的SQL语句映射。这个异常通常发生在以下几种情况下:
1. SQL语句映射错误:检查你的Mapper XML文件或注解中的SQL语句映射是否正确。确保SQL语句的id与Mapper接口中的方法名一致,并且Mapper接口的包路径与Mapper XML文件的namespace一致。
2. Mapper接口未被扫描到:确保你的Mapper接口被正确扫描到,并且被MyBatis正确管理。可以通过在启动类上添加`@MapperScan`注解来指定Mapper接口的扫描路径。
3. Mapper接口方法名错误:检查你的Mapper接口方法名是否与Mapper XML文件或注解中的SQL语句id一致。确保方法名的大小写和参数个数类型都匹配。
4. Mapper接口方法参数错误:检查你的Mapper接口方法参数是否与Mapper XML文件或注解中的SQL语句参数一致。确保参数个数、类型和顺序都匹配。
以下是一个示例,演示了如何解决"org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)"异常:
```java
// NewsDetailMapper.java
@Mapper
public interface NewsDetailMapper {
List<NewsDetail> selectByExample(NewsDetailExample example);
}
// NewsDetailMapper.xml
<mapper namespace="com.team.news.mapper.NewsDetailMapper">
<select id="selectByExample" resultType="com.team.news.model.NewsDetail">
SELECT * FROM news_detail WHERE ...
</select>
</mapper>
```
请注意,上述示例中的`NewsDetailExample`是一个自动生成的Example类,用于构建查询条件。
org.apache.ibatis.binding.BindingException: Invalidbound statement (not found)
当出现org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)错误时,通常是因为MyBatis无法找到对应的SQL语句映射。
要解决这个问题,可以按照以下步骤进行排查:
1. 首先,检查一下你的Mapper.xml文件中是否存在与该错误相关的SQL语句映射。确保SQL语句的id与Mapper接口中对应方法的名称一致。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* [mybatis访问报错:org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)...](https://blog.csdn.net/weixin_34402408/article/details/86024348)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
- *2* *3* [【报错解决】org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)](https://blog.csdn.net/qq_50914927/article/details/127091350)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]