Mybatis中接口和对应的mapper文件位置详解

一、引言

最近要新做一个平台项目,对于框架的搭建,当然是要给架构师来搭建和设计(所谓的架构,估计也是copy的)。Pull到搭完的项目后,在Mybaits的配置文件中,有几处和我之前自己搭建的框架不太一样,出于想知道有什么区别时,就顺口问了一下,结果得到的回复是:你的配置方式太老了,而且支持重复命名空间,我的这种是新的方式。听完,我,呵呵……所以,我就想记录一下,我对此的理解。

二、Maven打包分析

在 Maven 项目中,目录结构有:src/main/java 和 src/main/resources,前者是用来存放 Java 源代码的,后者是用来存放一些资源文件。一般情况下,我们用到的资源文件(各种xml,properites等)都放在该目录下面,在用 Maven 打包时,Maven 能把这些资源文件打包到相应的jar或者war里。

但有时候,比如 Mybatis 的 mapper.xml 文件,我们习惯把它 和 Mapper.java 放一起,都放在src/main/java下面(方便查看),这样在用 Maven 打包时,就需要修改 pom.xml 文件,来把 mapper.xml 文件一起打包进jar或者war里了(因为在默认的情况下,Maven打包的时候,对于src/main/java目录只打包源代码,而不会打包其他文件),否则,这些文件不会被打包的。(Maven 认为 src/main/java 只是Java的源代码路径)。此种方式需要在 pom.xml 文件中添加如下配置(也可以使用其他的配置方式,如 build-helper-maven-plugin、maven-resources-plugin插件):
这里写图片描述

三、Mybatis接口(Dao)和 mapper 文件位置

1、接口和文件放在同一个包中

Mybatis 中接口和对应的mapper文件不一定要放在同一个包下。如果放在一起,目的是为了 Mybatis 进行自动扫描,并且需要注意的是,此时Java接口的名称和mapper.xml文件的名称要相同(名称指的是包名,见下图),否则会报异常,由于此时 Mybatis 会自动解析对应的接口和相应的配置文件,所以就不需要配置mapper文件的位置了。
这里写图片描述
这里写图片描述

由于在默认的情况下,对于src/main/java目录,Maven只打包源代码,而不会打包其他文件。所以此时如果把对应的 mapper 文件放到src/main/java目录下时,不会打包到最终的jar文件夹中,也不会输出到target文件夹中,由于在进行单元测试的时候执行的是/target/test-classes下的代码,所以在测试的时候也不会成功。

为了实现在 Maven 默认环境下打包时,Mybatis 的接口和mapper.xml文件在同一包中,可以通过将接口文件(java文件)放在src/main/java某个包中,而在 src/main/resources 目录中建立同样的包,这是一种约定优于配置的方式,这样在maven打包的时候就会将src/main/java和src/main/resources相同包下的文件合并到同一包中。

在 src/main/java 和 src/main/resources 中相同的包名,相同的文件名,默认打包后的结构如下:
这里写图片描述

2、接口和文件不在同一个包下

该情况下的目录结构如下图所示:
这里写图片描述
如果 Dao 接口文件和 mapper.xml 文件不在同一个包下,就不能进行自动扫描解析了,需要对接口和mapper 文件分别进行配置。配置方式有两种:

(1)、不在Spring中配置、使用Mybatis的配置文件如下:
这里写图片描述

(2)在Spring 配置文件中配置如下:
这里写图片描述

我对第二种方式的理解是,Spring容器会加载扫描目录 mapper下xml文件,然后在通过该文件中的命名空间来找到接口文件 Dao 的所在位置,然后做出映射。


补充:

(3)在 SpringBoot 中使用注解 配置如下:
在application.yml或application.properties中配置Mybatis的配置文件和Mapper文件位置。

mybatis.config-location=classpath:Mybatis-config.xml
mybatis.mapper-locations=classpath:mybatis/mapper/*.xml

在启动类上,标注@MapperScan注解

@MapperScan({"com.scorpios.backend.sys.mapper")
public class BackendApplication {
    public static void main(String[] args) {
        SpringApplication.run(BackendApplication.class, args);
    }
}

在接口上使用@Mapper注解

@Mapper
public interface MenuMapper {
    int deleteById(Integer id);
    int insert(Menu menu);
    Menu getMenu(Integer id);
    int save(Menu menu);
}
  • 14
    点赞
  • 46
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

止步前行

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值