这个问题是:mapper.xml文件和mapper.java文件对应不上
情景:springboot项目,需要自定义SQL语句。其中有mapper.java, mapper.xml,dao.java
说明:mapper.java interface
mapper.xml和mapper.java相映射。
dao数据访问层。
访问逻辑 通过访问dao->mapper.java->mapper.xml
我的mapper.java 在src/main/java mapper.xml在resources下 两者路径不相同
当访问写在xml里面的自定义sql语句时,出现了org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)。
查网上有几种解决方案:
1:检查xml文件所在的package名称是否和interface对应的package名称一一对应
2:检查xml文件的namespace是否和xml文件的package名称一一对应
3:检查函数名称能否对应上
4:去掉xml文件中的中文注释
5:随意在xml文件中加一个空格或者空行然后保存
因为我的这一系列文件 对象model,mapper.java, mapper.xml 都是使用mybatis-generator自动生成的,所以基本上上面的5种都不能解决。并且我也通过事实证明了,确实没有解决。
继续查询,发现就是因为我的mapper.xml文件和mapper.java文件的目录不一样,而默认是一样的,所以必须重新说明。
ResourcePatternResolver resolver = new PathMatchingResourcePatternResolver(); sqlSessionFactory.setMapperLocations(resolver.getResources("classpath*:mappers/*.xml"));
详细解决方案:
创建MybatisConfig.java文件