Spring Boot整合mybatis报错Invalid bound statement (not found)
在第一次整合spring boot 与 mybatis 就遇到了一个深深的大坑,Invalid bound statement (not found): com.pn.mappers.LogMapper.insert 错误!!
这个错误是说,方法绑定无效
再报这个错误之前还报了
Field logService in com.pn.aspect.LogAop required a bean of type ‘com.pn.dao.LogDao’ that could not be found.
这个错误的大致意思是:
logService 类中需要一个’com.pn.dao.LogDao’,说明你的注入的dao层未生效;
图片:
报以上图片问题解决方案
在你的启动类上加入包扫描注解:
@MapperScan({“项目结构.dao层的包名称”})
最后报Invalid bound statement (not found): com.pn.mappers.LogMapper.insert 错误: 解决方案
我使用的解决方案如下:
将resources包下的mapper的上层目录创建的与dao层接口所在的目录结构一摸一样,这样打包时,就会将dao层接口和映射文件打包在一起,这个方法肯定不是最优解,但最简单,如下图所示:
如果使用@Autowired注入报红,可以使用@Repository注解(如图二所示):
也可以通过配置文件来解决:
下面这句不要加短横线
mapper-locations: classpath*:mappers(放xml文件的文件夹名)/*.xml
不管怎么样都是需要包扫描注解(@MapperScan)的哦!!!
我找了许多的博文,有些加入注解@MapperScan(),但只能解决我说的上述问题之一,不能彻底解决所报问题,最后,一定要看看自己的代码注解注入是不是全都有,还有包结构和名称,细心细心再细心!!!!
我的项目是在库中添加日志,用了切面和自定义注解!!!