Mybatis-Plus 自定义 SQL 无法执行

1. 检查 application.yml 文件中 mybatis-plus.mapper-locations 项是否准确

参考示例(能正确读取到):

yml设置:

mybatis-plus:
  mapper-locations: classpath*:**/mapper/xml/*.xml

注:

  1. ** 可以匹配多级目录

  2. classpath和classpath*区别:

    classpath:只会到你的class路径中查找找文件。

    classpath*:不仅包含class路径,还包括jar文件中(class路径)进行查找。

    注意: 用classpath*:需要遍历所有的classpath,所以加载速度是很慢的;因此,在规划的时候,应该尽可能规划好资源文件所在的路径,尽量避免使用classpath*。

目录结构:

image-20210129182955111

2. 对于IDEA系列编辑器,XML 文件是不能放在 java 文件夹中的,IDEA 默认不会编译源码文件夹中的 XML 文件,可以参照以下方式解决:
  • 将配置文件放在 resource 文件夹中
  • 对于 Maven 项目,可指定 POM 文件的 resource

即在 pom.xml 文件中添加如下:

<build>
  <resources>
      <resource>
          <!-- xml放在java目录下-->
          <directory>src/main/java</directory>
          <includes>
              <include>**/*.xml</include>
          </includes>
      </resource>
      <!--指定资源的位置(xml放在resources下,可以不用指定)-->
      <resource>
          <directory>src/main/resources</directory>
      </resource>
  </resources>
</build>

参考:

MyBatis-Plus官方文档-自定义 SQL 无法执行

Spring配置中的"classpath:"与"classpath*:"的区别研究

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值