详解MyBatis开发Dao层的两种方式(Mapper动态代理方式)

 更新时间:2018年12月14日 11:53:42   作者:谢亚峰  
这篇文章主要介绍了详解MyBatis开发Dao层的两种方式(Mapper动态代理方式),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

MyBatis开发原始Dao层请阅读我的上一篇博客:MyBatis开发Dao层的两种方式(原始Dao层开发)

接上一篇博客继续介绍MyBatis开发Dao层的第二种方式:Mapper动态代理方式

Mapper接口开发方法只需要程序员编写Mapper接口(相当于Dao接口),由Mybatis框架根据接口定义创建接口的动态代理对象,代理对象的方法体同上一篇博客中Dao接口实现类方法。

Mapper接口开发需要遵循以下规范:

(1)Mapper.xml文件中的namespace与mapper接口的类路径相同。

(2)Mapper接口方法名和Mapper.xml中定义的每个statement的id相同

(3)Mapper接口方法的输入参数类型和mapper.xml中定义的每个sql 的parameterType的类型相同

(4)Mapper接口方法的输出参数类型和mapper.xml中定义的每个sql的resultType的类型相同

1、定义mapper映射文件UserMapper.xml(内容同User.xml),需要修改namespace的值为 UserMapper接口路径。将UserMapper.xml放在classpath 下sqlmapperr目录下。

<?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="com.xyfer.mapper.UserMapper">
  <!-- 根据id查询用户 -->
  <select id="getUserById" parameterType="int" resultType="com.xyfer.po.User">
    select * from user where id = #{id}
  </select>
  <!-- 添加用户 -->
  <insert id="insertUser" parameterType="com.xyfer.po.User">
  <selectKey keyProperty="id" order="AFTER" resultType="java.lang.Integer">
    select LAST_INSERT_ID() 
  </selectKey>
   insert into user(username,birthday,sex,address) 
   values(#{username},#{birthday},#{sex},#{address})
  </insert>
  <!-- 修改用户 -->
  <update id="updateUser" parameterType="com.xyfer.po.User">
    update user set username=#{username},birthday=#{birthday},sex=#{sex},address=#{address}
    where id=#{id}
  </update>
  <!-- 删除用户 -->
  <delete id="deleteUserById" parameterType="int">
    delete from user where id=#{id}
  </delete>
 </mapper>

2、UserMapper.java接口文件

package com.xyfer.mapper;

import com.xyfer.po.User;

public interface UserMapper {
  
  public User getUserById(int id);  //根据id值查询一个用户
  public void insertUser(User user); //新增一个用户
  public void updateUser(User user); //修改一个用户
  public void deleteUser(int id);  //删除一个用户

}

接口定义有如下特点:

(1)UserMapper接口方法名和Mapper.xml中定义的statement的id相同

(2)UserMapper接口方法的输入参数类型和mapper.xml中定义的statement的parameterType的类型相同

(3) UserMapper接口方法的输出参数类型和mapper.xml中定义的statement的resultType的类型相同

3、在SqlMapConfig.xml文件中加载UserMapper.xml文件

<mappers>
  <mapper resource="UserMapper.xml"/>
</mappers>

4、测试

package com.xyfer.mapper;

import static org.junit.Assert.*;

import java.io.InputStream;
import java.util.Date;

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.Before;
import org.junit.Test;

import com.xyfer.po.User;

import junit.framework.TestCase;

public class UserMapperTest extends TestCase{

  private SqlSessionFactory sqlSessionFactory;
  
  protected void setUp() throws Exception {
    SqlSessionFactoryBuilder sessionFactoryBuilder = new SqlSessionFactoryBuilder();
    InputStream inputStream = Resources.getResourceAsStream("SqlMapConfig.xml");
    sqlSessionFactory = sessionFactoryBuilder.build(inputStream);
  }


  @Test
  public void testGetUserById() {
    //获取sqlsession
    SqlSession sqlsession = sqlSessionFactory.openSession();
    //获取UserMapper接口代理对象
    UserMapper userMapper = sqlsession.getMapper(UserMapper.class);
    //调用代理对象方法
    User user = userMapper.getUserById(10);
    //打印结果
    System.out.println(user);
    //关闭sqlsession
    sqlsession.close();
  }

  @Test
  public void testInsertUser() {
    //获取sqlsession
    SqlSession sqlsession = sqlSessionFactory.openSession();
    //获取UserMapper接口代理对象
    UserMapper userMapper = sqlsession.getMapper(UserMapper.class);
    //新建一个对象
    User user = new User();
    user.setUsername("小谢");
    user.setSex("男");
    user.setBirthday(new Date());
    user.setAddress("浙江省杭州市");
    //调用代理对象方法
    userMapper.insertUser(user);
    //关闭sqlsession
    sqlsession.close();
  }

  @Test
  public void testUpdateUser() {
    //获取sqlsession
    SqlSession sqlsession = sqlSessionFactory.openSession();
    //获取UserMapper接口代理对象
    UserMapper userMapper = sqlsession.getMapper(UserMapper.class);
    //新建一个对象
    User user = new User();
    user.setUsername("小谢");
    user.setSex("男");
    user.setBirthday(new Date());
    user.setAddress("上海市");
    //调用代理对象方法
    userMapper.updateUser(user);
    //关闭sqlsession
    sqlsession.close();
  }

  @Test
  public void testDeleteUser() {
    //获取sqlsession
    SqlSession sqlsession = sqlSessionFactory.openSession();
    //获取UserMapper接口代理对象
    UserMapper userMapper = sqlsession.getMapper(UserMapper.class);
    //调用代理对象方法
    userMapper.deleteUser(6);
    //关闭sqlsession
    sqlsession.close();
  }

}

以上步骤,完成mybatis框架以Mapper动态代理方式开发Dao层,并对数据库进行增删改查操作。

需要注意的是,上文提到的config文件夹和sqlmapper文件夹均为资源文件夹(source folder),默认会加载该路径下的文件。希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 详解java NIO之Channel(通道)

    详解java NIO之Channel(通道)

    这篇文章主要介绍了详解java NIO之Channel(通道)的相关资料,文中讲解非常详细,示例代码帮助大家更好的理解和学习,感兴趣的朋友可以了解下
    2020-07-07
  • Spring Cloud之注册中心Nacos的使用详解

    Spring Cloud之注册中心Nacos的使用详解

    本文介绍SpringCloud Alibaba中的Nacos组件,对比了Nacos与Eureka的区别,展示了如何在项目中引入SpringCloud Alibaba和Nacos,并配置负载均衡,通过实际操作,验证了服务注册和负载均衡的功能,感兴趣的朋友一起看看吧
    2025-03-03
  • Java编程中避免equals方法的隐藏陷阱介绍

    Java编程中避免equals方法的隐藏陷阱介绍

    这篇文章主要介绍了Java编程中避免equals方法的隐藏陷阱介绍,具有一定参考价值,需要的朋友可以了解下。
    2017-11-11
  • Java中的泛型和泛型通配符详解

    Java中的泛型和泛型通配符详解

    这篇文章主要介绍了Java中的泛型和泛型通配符详解,泛型的作用就是在编译的时候能够检查类型安全,并且所有的强制转换都是自动和隐式的在没有泛型的情况的下,通过对类型Object的引用来实现参数的“任意化”,需要的朋友可以参考下
    2023-07-07
  • java实现微信扫码登录第三方网站功能(原理和代码)

    java实现微信扫码登录第三方网站功能(原理和代码)

    为避免繁琐的注册登陆,很多平台和网站都会实现三方登陆的功能,增强用户的粘性。这篇文章主要介绍了java实现微信扫码登录第三方网站功能(原理和代码),避免做微信登录开发的朋友们少走弯路
    2022-12-12
  • Hibernate映射文件id的generator配置方法

    Hibernate映射文件id的generator配置方法

    下面小编就为大家分享一篇Hibernate映射文件id的generator配置方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2017-12-12
  • Jenkins初级使用过程中的异常处理

    Jenkins初级使用过程中的异常处理

    这篇文章主要为大家介绍了Jenkins初级使用过程中的异常处理,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步早日升职加薪
    2022-04-04
  • Java实现将txt/word/pdf转成图片并在线预览的功能

    Java实现将txt/word/pdf转成图片并在线预览的功能

    本文将基于aspose-words(用于txt、word转图片),pdfbox(用于pdf转图片),封装成一个工具类来实现txt、word、pdf等文件转图片的需求并实现在线预览功能,需要的可以参考一下
    2023-05-05
  • SpringBoot+MinIO+KKFileView实现文件预览功能

    SpringBoot+MinIO+KKFileView实现文件预览功能

    本文主要介绍了使用SpringBoot、MinIO和KKFileView实现文件上传和在线预览功能,通过配置MinIO存储文件,并使用KKFileView生成预览链接,感兴趣的可以了解一下
    2024-11-11
  • idea工具栏如何添加快捷图标的操作

    idea工具栏如何添加快捷图标的操作

    这篇文章主要介绍了idea工具栏如何添加快捷图标的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-02-02

最新评论