赞
踩
小伙伴们大家好,很快嗷,到了年后的第一周,最近在自己电脑上敲项目时遇到一个平时可能不怎么遇到的问题,就是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,没有报错
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。