BindingException异常的产生原因及解决过程详解
一. 问题背景
今天我在讲完MyBatis后,学生在进行代码练习时遇到了下面这样的一个异常,先上图:
二. 问题分析
1.原因分析
首先我们看到,这里抛出的异常是org.apache.ibatis.binding.BindingException,接着再看异常的信息是 Invalid bound statement (not found): com.qf.mapper.EmpMapper.list。基于这两点,我们大概能定位到是Mapper绑定产生的异常。
我们知道,在MyBatis中我们需要先定义一个Mapper接口,在接口中定义方法。然后再定义一个Mapper.xml,在XML文件中编写方法对应的SQL语句,这也是java代码和sql语句分离的体现。我们在调用Mapper接口中的方式时MyBatis会给我们创建一个该接口的代理类,通过代理类来调用Mapper接口中的方法。
现在有了代理就可以调用方法了,但是怎么找到这个方法对应的SQL语句呢?此时就需要把Mapper接口和Mapper.xml进行绑定,只有绑定了MyBatis才知道方法对应的sql语句,我们通过代理调用方法时才能正常运行sql语句。那么这个异常就是报的绑定异常,说没有找到com.qf.mapper.EmpMapper.list()对应的sql语句。
那如何把它们两个绑定呢?看下面代码。
2.定义EmpMapper接口
package com.qf.mapper;import com.qf.core.dao.BaseDao;import com.qf.entity.Emp;import org.omg.CORBA.INTERNAL;public interface EmpMapper extends BaseDao { public Emp selectById(Integer empno);}
3.定义EmpMapper.xml
在Mapper.xml中通过namespace属性和接口绑定,这个属性中设置的需要绑定的接口全类名。这里设置的是com.qf.mapper.EmpMapper,就代表当前EmpMapper.xml就和EmpMapper.java绑定了。然后在通过
4.问题原因
现在知道MyBatis的绑定的过程了,我们继续回到上面提到的异常。
通过检查学生的代码发现,这个学员只是在Mapper接口中定义了方法,但是没有在Mapper.xml中编写的sql语句,所以MyBatis找不到sql语句就抛出了上面的异常。
三. 异常解决
对于上面的异常,其实我们只需要在Mapper.xml中添加对应的sql语句就可以解决。该学员的这个bug的原因是因为没有写sql语句导致的。但是除了这个原因外,还有其他的场景也会导致出现这个bug,在这里都统一列出来方便大家学习,常见原因如下。
1.Mapper.xml中的namespace属性写错了
2.Mapper.java中的方法名称和Mapper.xml中标签id的属性不一致
3.Mapper.java中定义了方法,但是没有写Mapper.xml中对应的slq语句
4.Mapepr.xml没有给MyBatis注册
5.Mapepr.xml中的id最好和方法名称保持一致,而且Mapper.java中的方法名称不要重载。方法中是可以重载的,但是Mapepr.xml中的id是不允许重复的。
来源地址:https://blog.csdn.net/finally_vince/article/details/128464897
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341