当前位置:   article > 正文

【.xml文件匹配不到】⭐️解决使用mybatis-plus找不到对应的xml文件导致的持久层方法报错_invalid bound statement (not found): com.example.d

invalid bound statement (not found): com.example.demo.mapper.demomapper.find

前言

        小伙伴们大家好,很快嗷,到了年后的第一周,最近在自己电脑上敲项目时遇到一个平时可能不怎么遇到的问题,就是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语句即可,但是该方法不方便维护,遇到一些多表查询情况很混乱

  1. @Select("select * from customers")
  2. List<customers> getCustomers();

        方案2. 直接复制原来的xml文件到target目录中,手动完成加载,也是不方便使用

⭐️   方案3.通过配置解决,一劳永逸

        (1)首先在项目的pom.xml文件中的<build>标签下加入下面的配置

  1. <build>
  2. <!-- 项目打包时会将java目录中的*.xml文件也进行打包 -->
  3. <resources>
  4. <resource>
  5. <directory>src/main/java</directory>
  6. <includes>
  7. <include>**/*.xml</include>
  8. </includes>
  9. <filtering>false</filtering>
  10. </resource>
  11. </resources>
  12. </build>

        (2)在application.properties文件中添加如下配置

  1. #配置mapper xml的路径
  2. mybatis-plus.mapper-locations=classpath:com/example/demo/**/*.xml

        我的项目文件结构如下

 

测试:

        再测试下接口,ok,没有报错

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/168940
推荐阅读
相关标签
  

闽ICP备14008679号