前言
小伙伴们大家好,很快嗷,到了年后的第一周,最近在自己电脑上敲项目时遇到一个平时可能不怎么遇到的问题,就是mybatis持久层框架使用时找不到对应的xml配置文件,也就导致自己写的持久层方法报错
接口报错内容:
org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.example.demo.mapper.customersMapper.getCustomers
分析:
首先检查下映射文件中的id,resultMap等属性是否正确匹配,这里我的配置是没有问题的
原因:
搜了下该问题的原因,是maven默认的加载机制造成的问题,只把文件中.java类型的文件进行编译,其他类型的文件不会加载比如.xml,验证方式就是看target目录下有没有对应的mapper映射文件,我这里是因为这个原因,没有加载.xml文件
解决方案:
方案1.直接使用注解方式,在持久层方法上加对应注解,填充sql语句即可,但是该方法不方便维护,遇到一些多表查询情况很混乱
@Select("select * from customers")List<customers> getCustomers();
方案2. 直接复制原来的xml文件到target目录中,手动完成加载,也是不方便使用
⭐️ 方案3.通过配置解决,一劳永逸
(1)首先在项目的pom.xml文件中的<build>标签下加入下面的配置
<build>
<!-- 项目打包时会将java目录中的*.xml文件也进行打包 --><resources><resource><directory>src/main/java</directory><includes><include>**/*.xml</include></includes><filtering>false</filtering></resource></resources></build>
(2)在application.properties文件中添加如下配置
#配置mapper xml的路径
mybatis-plus.mapper-locations=classpath:com/example/demo/**/*.xml
我的项目文件结构如下
测试:
再测试下接口,ok,没有报错