org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): person.wgy.dao.BookDao.selectList
时间: 2023-06-19 16:07:26 浏览: 70
这个错误提示是 MyBatis 框架抛出的,意思是说找不到对应的 SQL 语句,也就是说在 BookDao.xml 文件中没有定义 selectList 这个 id 的语句。
解决方法:
1. 检查 BookDao.xml 文件中是否存在 selectList 这个 id 的语句,如果不存在则添加。如果存在,则检查该语句的 namespace 是否正确。
2. 检查 BookDao 接口的注解或者 XML 配置文件中 namespace 是否正确。
3. 检查 BookDao 接口中方法名是否与 BookDao.xml 文件中定义的 id 相匹配。
4. 检查是否将 BookDao.xml 文件正确地添加到了 MyBatis 的配置文件中。
如果以上方法都无法解决问题,可以尝试使用 MyBatis 的日志功能查看详细的错误信息,以便更好地定位问题。
相关问题
org.apache.ibatis.binding.BindingException: Invalid bound statement (not found):selectlist
`org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)`异常通常是因为MyBatis找不到映射文件中的某个语句引起的。这个异常通常有两种情况:
1.映射文件中没有定义该语句。
2.映射文件中定义了该语句,但是语句的ID与调用时的ID不匹配。
解决这个异常的方法如下:
1.检查映射文件中是否定义了该语句,如果没有定义,则需要添加该语句的定义。
2.检查调用时的ID是否与映射文件中定义的ID匹配,如果不匹配,则需要修改调用时的ID。
下面是一个例子,演示了如何解决`org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)`异常:
```java
// 映射文件中的语句定义
<select id="selectList" resultType="com.team.news.model.NewsDetail">
select * from news_detail
</select>
// 调用时的语句ID与映射文件中的语句ID不匹配,会抛出异常
List<NewsDetail> newsList = sqlSession.selectList("com.team.news.mapper.NewsDetailMapper.selectByExample");
// 修改调用时的语句ID,使其与映射文件中的语句ID匹配
List<NewsDetail> newsList = sqlSession.selectList("com.team.news.mapper.NewsDetailMapper.selectList");
```
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类,用于构建查询条件。