Mapper接口和mapper.xml的文件位置问题

 

       我们知道在典型的maven工程中,目录结构有:src/main/java和src/main/resources,前者是用来存放java源代码的,后者则是存放一些资源文件,比如配置文件等.   
      Mybatis中接口和对应的mapper文件不一定要放在同一个包下,如果放在一起的目的是为了Mybatis进行自动扫描,并且要注意此时Java接口的名称和mapper文件的名称要相同,否则会报异常,由于此时Mybatis会自动解析对应的接口和相应的配置文件,所以就不需要配置mapper文件的位置了。
1:接口和文件放在同一个包中如下:
在默认的情况下maven打包的时候,对于src/main/java目录只打包源代码,而不会打包其他文件。所以此时如果把对应的mapper文件放到src/main/java目录下时,不会打包到最终的jar文件夹中,也不会输出到target文件夹中,由于在进行单元测试的时候执行的是/target目录下/test-classes下的代码,所以在测试的时候也不会成功。


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

在默认maven打包的环境下,不要将接口文件和mapper文件全部放到src/main/java,这样也不会把mapper文件打包进去

在src/main/java和src/main/resources中相同的包名,相同的文件名,默认打包后的结构如下:

发现打包之后已经到同一个包下了。

而当你把接口和mapper文件全部放到src/main/java中同一包时,如下:

打包之后的文件如下:

发现编译打包之后并没有mapper文件,所以此时不管是测试还是正式执行都会出错!!


更改maven构建配置
如果不想将接口和mapper文件分别放到src/main/java和src/main/resources中,而是全部放到src/main/java,那么在构建的时候需要指定maven打包需要包括xml文件,具体配置如下:

 

<build>
    <resources>
        <resource>
            <directory>src/main/java</directory>
            <includes>
                <include>**/*.xml</include>
            </includes>
            <filtering>false</filtering>
        </resource>
    </resources>
</build>


这样在打包的时候也会将mapper文件打包到/target文件夹中。
2:接口和文件不在同一个包下

如果接口和mapper文件不在同一个包下,就不能进行自动扫描解析了,需要对接口和文件分别进行配置。
2.1 XML配置方式
2.1.1 不使用Spring
使用Mybatis的配置文件如下:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
  PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
  <mappers>
    <!-- 扫描路径下的mapper映射文件 -->
    <mapper resource="mappers/UserMapper.xml"/>
    <!-- 扫描包下的接口文件 -->
    <package name="edu.zju.bme.data.manage.mapper" />
  </mappers>
</configuration>


2.1.2 使用Spring
使用spring的配置文件如下:

<beans xmlns="http://www.springframework.org/schema/beans"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xmlns:mybatis="http://mybatis.org/schema/mybatis-spring"
  xsi:schemaLocation="
  http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
  http://mybatis.org/schema/mybatis-spring http://mybatis.org/schema/mybatis-spring.xsd">
  <!-- 配置接口存储的包,用来扫描mapper接口 -->
  <mybatis:scan base-package="edu.zju.bme.data.manage.mapper" />
  <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    <!-- 配置mapper文件位置,扫描映射文件,可以使用Ant风格的路径格式 -->
    <property name="mapperLocations" value="classpath*:mappers/**/*.xml" />
    // ...
  </bean>
</beans>


--------------------- 
作者:前行的道路 
来源:优快云 
原文:https://blog.youkuaiyun.com/fanfanzk1314/article/details/71480954/ 
版权声明:本文为博主原创文章,转载请附上博文链接!

在MyBatis框架中,@Mapper注解mapper.xml文件是可以同时使用的。@Mapper注解用于标识一个接口为MyBatis的Mapper接口,而mapper.xml文件则用于定义具体的SQL语句映射关系。 具体来说: 1. **@Mapper注解**:用于标识一个接口为MyBatis的Mapper接口。通过这个注解,MyBatis会自动扫描到这个接口并生成相应的代理对象,从而实现数据库操作。 2. **mapper.xml文件**:用于定义具体的SQL语句映射关系。通过XML文件,可以更加灵活地编写复杂的SQL语句进行结果集映射。 在实际使用中,可以通过以下几种方式同时使用@Mapper注解mapper.xml文件: ### 方法一:在接口上使用@Mapper注解,并在XML文件中定义SQL语句 ```java @Mapper public interface UserMapper { User selectUserById(Integer id); } ``` ```xml <!-- UserMapper.xml --> <mapper namespace="com.example.mapper.UserMapper"> <select id="selectUserById" resultType="com.example.model.User"> SELECT * FROM users WHERE id = #{id} </select> </mapper> ``` ### 方法二:在接口上使用@Mapper注解,并在接口方法上使用@Select等注解 ```java @Mapper public interface UserMapper { @Select("SELECT * FROM users WHERE id = #{id}") User selectUserById(Integer id); } ``` ### 方法三:混合使用@Mapper注解、@Select等注解mapper.xml文件 ```java @Mapper public interface UserMapper { @Select("SELECT * FROM users WHERE id = #{id}") User selectUserById(Integer id); User selectUserByName(String name); } ``` ```xml <!-- UserMapper.xml --> <mapper namespace="com.example.mapper.UserMapper"> <select id="selectUserByName" resultType="com.example.model.User"> SELECT * FROM users WHERE name = #{name} </select> </mapper> ``` 通过以上方式,可以灵活地使用@Mapper注解mapper.xml文件进行数据库操作。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值