欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

解决Spring boot整合mybatis,xml资源文件放置及路径配置问题

程序员文章站 2022-03-13 22:33:31
网上各种解决方案,我试了好久,整合了几篇文章才凑出来,在这里分享一下,实在不想网友们在这里面绕圈子,毕竟,写代码的时间是愉快的,解决bug也是愉快的,但也是一直在bug里面绕圈子就不爽了。亲自试验:1...

网上各种解决方案,我试了好久,整合了几篇文章才凑出来,在这里分享一下,实在不想网友们在这里面绕圈子,毕竟,写代码的时间是愉快的,解决bug也是愉快的,但也是一直在bug里面绕圈子就不爽了。

亲自试验:

1) 我的mapper和xml是这样子放置的

解决Spring boot整合mybatis,xml资源文件放置及路径配置问题

2) 在.xml中namespace是这样的:

解决Spring boot整合mybatis,xml资源文件放置及路径配置问题

3) application.properties中mybatis.mapper-locations得这么配置到xml

解决Spring boot整合mybatis,xml资源文件放置及路径配置问题

4) 最后呢,你只要在pom.xml中build下这样配置

解决Spring boot整合mybatis,xml资源文件放置及路径配置问题

5) 按照我这种位置防止,把响应的包名换成自己的,就基本上不会没有什么问题的。

也不用去加什么*application中去加什么注解@mapperscan(value = "com.acme.shop.mapper")什么的了,不需要呢。

补充知识:mybatis-plus的 mapper.xml 路径配置的坑

问题:

在springboot整合mybatis时,若mapper映射文件在java路径下,就会一直报错invalid bound statement (not found): xxx.xxxmapper.selectxx

解决Spring boot整合mybatis,xml资源文件放置及路径配置问题

说明mapper接口是可以调用到的,问题就出在无法映射到mapper.xml文件。

同时查看输出target目录下,没有xxxmapper.xml文件的编译结果。

原因:

springboot默认配置情况下,只有resources路径下的xml文件会被扫描。

解决办法:

方法一:【推荐使用】

将mapper映射文件放在resources目录下,通常会在resources目录下建一个mapper目录,存放各种mapper的映射文件,

解决Spring boot整合mybatis,xml资源文件放置及路径配置问题

并且在application.properties中配置 mapper映射文件的路径为:

#指定mybatis的核心配置文件与mapper映射文件

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

测试成功,查看target目录下,有xxxmapper.xml文件的编译结果。

解决Spring boot整合mybatis,xml资源文件放置及路径配置问题

方法二:

mapper映射文件依旧放在java目录下,

解决Spring boot整合mybatis,xml资源文件放置及路径配置问题

此时,需要在pom.xml文件中添加java路径下xml文件扫描配置,

 <build>
   <resources>
     <resource>
      <filtering>true</filtering>
      <directory>${basedir}/src/main/java</directory>
      <includes>
        <include>**/*.xml</include>
      </includes>
     </resource>
     <resource>
      <directory>${basedir}/src/main/java</directory>
      <excludes>
        <exclude>**/*.xml</exclude>
      </excludes>
     </resource>
   </resources>
</build>

并且在application.properties中配置 mapper映射文件的路径时要加上包名,

#mybatis.mapper-locations=classpath:包名/*.xml

mybatis.mapper-locations=classpath:org.xiao.dao/*.xml

测试成功,查看target目录下,有xxxmapper.xml文件的编译结果。

解决Spring boot整合mybatis,xml资源文件放置及路径配置问题

以上这篇解决spring boot整合mybatis,xml资源文件放置及路径配置问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。