mybatis使用mapper代理开发方式

 更新时间:2024年10月19日 09:50:11   作者:xvwen  
使用MyBatis代理开发模式时,需要注意定义与映射配置文件同名的接口类,确保namespace属性与接口路径一致,接口方法名和映射文件中的id名称相同,返回类型保持一致,在mybatis-config.xml中配置映射文件路径,保证结构一致,可通过注解@Param传递多个参数

mapper代理开发规则

使用mybatis的代理开发,不仅可以用来管理冗多的xml配置文件,还可以解决硬编码,传递多个参数,简化执行sql的优点。

主要有以下注意事项:

  1. 定义与映射的配置文件(UserMapper.xml)同名的接口类,并且要在同一目录下。
  2. 映射文件中的namspace属性为接口类的路径。
  3. 在接口类中实现映射的配置文件方法时,方法名和映射文件的id属性的名称一样。返回数据类型也一样。
  4. mybatis-config.xml的映射配置文件的路径要一一对应。

对上面有疑惑的可以看我之前的文章 mybatis基础

创建mapper目录结构和映射接口类

根据上面的规则来具体实现,在java目录下创建mapper软件包,将UserMapper接口放在该目录下。

在resources下创建mapper目录,将隐射配置文件放在该目录下。

可以下载mybatisX插件将两者联系起来。

maven目录结构下,java和resources编译后在同一目录下,他们里面的包也是。

所以满足规则但是层级结构必须一样。

当然也可以直接将xml放在java目录下的mapper包中即和UserMapper在一起,就不需要考虑其他问题了。满足第一个规则。

修改映射配置文件的namespace属性

使用mapper映射代理开发,这个属性就显得尤为重要,UserMapper接口(映射接口类)和UserMapper.xml

(映射配置文件)的联系都是产生于namespace属性。

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="mapper.UserMapper">
        <select id="selectAll" resultType="model.User">
            select * from user
        </select>

        <select id="selectById" resultType="model.User">
            select  * from user where id=#{id}
        </select>
</mapper>

将namespace的内容由test(自定义)改为mapper.UserMapper(映射接口所在的路径)。满足第二个规则。

编写映射接口类的方法

package mapper;

import model.User;
import java.util.List;

public interface UserMapper {
    List<User> selectAll();  //默认public关键字修饰,selectAll对应xml的id属性

}

前面我们知道xml配置文件的id属性本身时一个方法,可以看作mybatis将其封装为一个resultSet(jdbc)的结果集,接口的作用主要是继承该方法并处理结果集。

用list集合存储结果集。满足第三个规则

修改mybatis-config.xml的映射配置文件的路径

<?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>
  <environments default="development">
    <environment id="development">
      <transactionManager type="JDBC"/>
      <dataSource type="POOLED">
      <!--连接配置->
        <property name="driver" value="${driver}"/>
        <property name="url" value="${url}"/>
        <property name="username" value="${username}"/>
        <property name="password" value="${password}"/>
      </dataSource>
    </environment>
  </environments>
  <mappers>
 	<!--mappper映射路径-->
    <mapper resource="UserMapper.xml"/>
  </mappers>
</configuration>

要修改的只有mapper标签下颚resource属性,内容为映射配置文件的路径:mapper/UserMapper.xml

这是我的目录结构每个人的不一样。

当然你的映射配置文件较多时直接用packge标签把整个mapper包直接加载进来(包扫描)

如果时直接把包导入的话,就不是/来展现目录的层级了,而是.来体现。如util.chapter.mapper。实现规则四。

编写测试类调用方法

package mybatis;
import mapper.UserMapper;
import model.User;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Test;

import java.io.IOException;
import java.io.InputStream;
import java.util.List;

public class MybatisTest {

    @Test
    public void method() throws IOException {     //单元测试不能要static
        //mybatis框架都在xml配置文件中加载配置文件
        //从 XML 文件中构建 SqlSessionFactory 的实例
        String resource = "mybatis-config.xml";
        InputStream inputStream = null;

        inputStream = Resources.getResourceAsStream(resource);

        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

        //从 SqlSessionFactory 中获取 SqlSession
        SqlSession session = sqlSessionFactory.openSession();


        //执行sql
        //List<User> users=session.selectList("test.selectAll");
        //System.out.println(users);

        //mapper代理执行sql
        UserMapper userMapper=session.getMapper(UserMapper.class);
        List<User> users= userMapper.selectAll();  //UserMapper接口的实现方法
        System.out.println(users);

        //释放资源
        session.close();

    }
}

注意要导入javabean和映射接口类。使用代理和不使用的区别。

如下面的映射文件的配置,那么如何调用有多个参数的方法呢?

配置文件xml

<select id="selectAll" resultType="model.User">
	select * from user
</select>

<select id="selectById" resultType="model.User">
    select  * from user where id=#{id}
</select>

<select id="selectmore" resultType="model.User">
    select * from user where id =#{id} and username=#{username}
</select>

映射接口类

List<User> selectAll();  //默认public关键字修饰
List<User> selectById(int id);
List<User> selectMore(int id,String name);

mybatis的参数传递:

当传递多个不同类型的参数时mybatis将参数封装为map集合,并默认有key,可以通过@param注解更改key的名称,value保留参数的值,通过更改后的key名称获取参数。当只有一个参数时就不用了。

javabean的参数类型:可以直接使用,对象的属性名和参数占位符保持一致即可,上面使用的reultType手势javabean对象,位置对应就可以了。

Map集合 :map的键和参数占位符一致也直接使用。

(上面的数据类型可以直接传递,位置对应即可)

array,list当数据类型都要加注解@param。

实际上sql的占位符会接收该方法传递的参数,mybatis是将参数封装为一个map集合,占位符的名称就是key,但是系统默认的key并不是,需要用@param将默认的key改为占位符的名称就可以了。

具体操作就是@param中的值与xml文件的占位符一致就可以了,紧跟着就是参数了。调用也是按位置传参。

所有数据类型的都可以用注解@Param来传参(P大写)。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 关于Java中的dozer对象转换问题

    关于Java中的dozer对象转换问题

    Dozer是Java Bean到Java Bean映射器,它以递归方式将数据从一个对象复制到另一个对象,这篇文章主要介绍了Java中的dozer对象转换的操作方法,需要的朋友可以参考下
    2022-08-08
  • 超详细解析Spring Bean的创建过程

    超详细解析Spring Bean的创建过程

    这篇文章主要揭秘了Spring Bean的创建过程,文中通过代码示例和图文结合的方式解析的超级详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2024-05-05
  • Mybatis利用分页插件PageHelper快速实现分页查询

    Mybatis利用分页插件PageHelper快速实现分页查询

    如果你也在用MyBatis,建议尝试该分页插件,这一定是最方便使用的分页插件,这篇文章主要给大家介绍了关于Mybatis利用分页插件PageHelper快速实现分页查询的相关资料,PageHelper是一个Mybatis的分页插件,负责将已经写好的sql语句,进行分页加工,需要的朋友可以参考下
    2021-08-08
  • spring aop实现接口超时处理组件的代码详解

    spring aop实现接口超时处理组件的代码详解

    这篇文章给大家介绍了spring aop实现接口超时处理组件,文中有详细的实现思路,并通过代码示例给大家介绍的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2024-02-02
  • Spring拦截器中注入Bean失败解放方案详解

    Spring拦截器中注入Bean失败解放方案详解

    这两天遇到SpringBoot拦截器中Bean无法注入问题。下面介绍关于SpringBoot拦截器中Bean无法注入的问题解决方案,感兴趣的朋友一起看看吧
    2022-06-06
  • Kotlin lateinit与by lazy案例详解

    Kotlin lateinit与by lazy案例详解

    这篇文章主要介绍了Kotlin lateinit与by lazy案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-09-09
  • java中的常用集合类整理

    java中的常用集合类整理

    本篇文章给大家带来的内容是关于java中List集合及其实现类的方法介绍(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。下面我们就来学习一下吧,希望能给你带来帮助
    2021-06-06
  • 解决Weblogic部署war找不到spring配置文件的问题

    解决Weblogic部署war找不到spring配置文件的问题

    这篇文章主要介绍了解决Weblogic部署war找不到spring配置文件的问题,具有很好的参考价值,希望对大家有所帮助。
    2021-07-07
  • 浅谈hibernate中懒加载禁用操作

    浅谈hibernate中懒加载禁用操作

    这篇文章主要介绍了浅谈hibernate中懒加载禁用操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-10-10
  • java内存泄漏与内存溢出关系解析

    java内存泄漏与内存溢出关系解析

    这篇文章主要介绍了java内存泄漏与内存溢出关系解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12

最新评论