Invalid bound statement (not found):mapper.method] with root cause
在刚接手一个新项目时,我按照原有的开发习惯,编写了一套接口,在实现类中写具体的业务实现,example:xxxServiceImpl implements xxxService。业务逻辑编写完在接口DEBUG调试的时候,跳不进去业务层的处理逻辑。查看异常抛出,分析是mybatis的问题,仔细检查过了xml与mapper之前包的路径是否引错,还是mapper中的接口参数与xml中编写的是否一致,但是都没问题。经过分析,发现是mybatis的扫描路径包括了项目目录下的所有包,这就导致把我自己写的接口实现类又加入到了SpringIOC容器,而我的实现类通过@Service注解已经加过容器中了,所以,当获取到的JDK代理对象不是唯一时,因为我是用@Autowire注入的方式拿到对象的,所以就会导致该对象没有我们预想的方法可以供我们调用。
解决办法:解决方案有很多,我觉得主要的问题第一个是工程目录结构是比较老的项目,一般我们的xml文件以及mapper都是放到resource目录,让scanner扫描指定包下的文件即可,所以引发了这种问题,最后我的解决办法是删掉interface层,直接编写业务类。当然你可以修改扫描包,或者不要用@Autoware注解,而是指定名字的方式获取实例。