详解mybatis通过mapper接口加载映射文件

 更新时间:2017年08月10日 09:28:58   作者:YSOcean  
本篇文章主要介绍了mybatis通过mapper接口加载映射文件 ,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

通过 mapper 接口加载映射文件,这对于后面 ssm三大框架 的整合是非常重要的。那么什么是通过 mapper 接口加载映射文件呢?

我们首先看以前的做法,在全局配置文件 mybatis-configuration.xml 通过 <mappers> 标签来加载映射文件,那么如果我们项目足够大,有很多映射文件呢,难道我们每一个映射文件都这样加载吗,这样肯定是不行的,那么我们就需要使用 mapper 接口来加载映射文件

以前的做法:

  

改进做法:使用 mapper 接口来加载映射文件

1、定义 userMapper 接口

package com.ys.mapper;

 

import org.apache.ibatis.annotations.Delete;

import org.apache.ibatis.annotations.Insert;

import org.apache.ibatis.annotations.Select;

import org.apache.ibatis.annotations.Update;

 

import com.ys.po.User;

 

public interface UserMapper {

  //根据 id 查询 user 表数据

  public User selectUserById(int id) throws Exception;

 

  //向 user 表插入一条数据

  public void insertUser(User user) throws Exception;

   

  //根据 id 修改 user 表数据

  public void updateUserById(User user) throws Exception;

   

  //根据 id 删除 user 表数据

  public void deleteUserById(int id) throws Exception;

} 

2、在全局配置文件 mybatis-configuration.xml 文件中加载 UserMapper 接口(单个加载映射文件)

3、编写UserMapper.xml 文件

<?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.ys.mapper.UserMapper">

 

   

  <!-- 根据 id 查询 user 表中的数据

    id:唯一标识符,此文件中的id值不能重复

    resultType:返回值类型,一条数据库记录也就对应实体类的一个对象

    parameterType:参数类型,也就是查询条件的类型

  -->

  <select id="selectUserById"

      resultType="com.ys.po.User" parameterType="int">

    <!-- 这里和普通的sql 查询语句差不多,后面的 #{id}表示占位符,里面不一定要写id,写啥都可以,但是不要空着 -->

    select * from user where id = #{id1}

  </select>

   

   

   

  <!-- 根据 id 更新 user 表的数据 -->

  <update id="updateUserById" parameterType="com.ys.po.User">

    update user u

      <!-- <set>

        <if test="username != null and username != ''">

          u.username = #{username},

        </if>

        <if test="sex != null and sex != ''">

          u.sex = #{sex}

        </if>

      </set> -->

      <trim prefix="set" suffixOverrides=",">

        <if test="username != null and username != ''">

          u.username = #{username},

        </if>

        <if test="sex != null and sex != ''">

          u.sex = #{sex},

        </if>

      </trim>

     

     where id=#{id}

  </update>

   

   

  <!-- 向 user 表插入一条数据 -->

  <insert id="insertUser" parameterType="com.ys.po.User">

    <!-- 将插入的数据主键返回到 user 对象中

       keyProperty:将查询到的主键设置到parameterType 指定到对象的那个属性

       select LAST_INSERT_ID():查询上一次执行insert 操作返回的主键id值,只适用于自增主键

       resultType:指定 select LAST_INSERT_ID() 的结果类型

       order:AFTER,相对于 select LAST_INSERT_ID()操作的顺序

     -->

    <selectKey keyProperty="id" resultType="int" order="AFTER">

      select LAST_INSERT_ID() 

    </selectKey>

    insert into user(username,sex,birthday,address)

      value(#{username},#{sex},#{birthday},#{address})

  </insert>

   

   

   

  <!-- 根据 id 删除 user 表的数据 -->

  <delete id="deleteUserById" parameterType="int">

    delete from user where id=#{id}

  </delete>

   

</mapper> 

4、测试

//根据id查询user表数据

@Test

public void testSelectUserById(){

  /*这个字符串由 userMapper.xml 文件中 两个部分构成

    <mapper namespace="com.ys.po.userMapper"> 的 namespace 的值

    <select id="selectUserById" > id 值*/

  String statement = "com.ys.mapper.UserMapper.selectUserById";

  User user = session.selectOne(statement, 1);

  System.out.println(user);

  session.close();

} 

5、批量加载映射文件

<mappers>

    <!--批量加载mapper

     指定 mapper 接口的包名,mybatis自动扫描包下的mapper接口进行加载

     -->

    <package name="com.ys.mapper"/>

</mappers> 

6、注意 

1、UserMapper 接口必须要和 UserMapper.xml 文件同名且在同一个包下,也就是说 UserMapper.xml 文件中的namespace是UserMapper接口的全类名

  

2、UserMapper接口中的方法名和 UserMapper.xml 文件中定义的 id 一致

3、UserMapper接口输入参数类型要和 UserMapper.xml 中定义的 parameterType 一致

4、UserMapper接口返回数据类型要和 UserMapper.xml 中定义的 resultType 一致

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 详解java如何处理各种批量数据入库

    详解java如何处理各种批量数据入库

    这篇文章主要为大家详细介绍了java如何使用BlockingQueue处理各种批量数据入库,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-11-11
  • 在SpringBoot中使用HATEOAS的方法

    在SpringBoot中使用HATEOAS的方法

    这篇文章主要介绍了在SpringBoot中使用HATEOAS的方法,HATEOAS是实现REST规范的一种原则,通过遵循HATEOAS规范,可以解决我们实际代码实现的各种个问题,下文更多相关介绍,需要的小伙伴可以参考一下
    2022-05-05
  • SpringBoot项目如何打可执行war包

    SpringBoot项目如何打可执行war包

    最近小编做了一个springboot项目,最后需要打成war包在容器中部署,下面小编给大家分享下SpringBoot项目如何打可执行war包,感兴趣的朋友一起看看吧
    2020-04-04
  • SpringBoot 属性配置中获取值的方式

    SpringBoot 属性配置中获取值的方式

    这篇文章主要介绍了SpringBoot 属性配置中获取值的方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-02-02
  • 比较常用UML类图几种关系的小结

    比较常用UML类图几种关系的小结

    本文给大家总结了UML类图中几种比较常用的关系小总结,需要的朋友可以参考下
    2015-10-10
  • SpringMVC + jquery.uploadify实现上传文件功能

    SpringMVC + jquery.uploadify实现上传文件功能

    文件上传是很多项目都会使用到的功能,SpringMVC当然也提供了这个功能。不过小编不建议在项目中通过form表单来提交文件上传,这样做的局限性很大。下面这篇文章主要介绍了利用SpringMVC + jquery.uploadify实现上传文件功能的相关资料,需要的朋友可以参考下。
    2017-06-06
  • 为何Java8需要引入新的日期与时间库

    为何Java8需要引入新的日期与时间库

    这篇文章主要给大家介绍了关于Java8为什么需要引入新的日期与时间库的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • Java的覆写操作实例分析

    Java的覆写操作实例分析

    这篇文章主要介绍了Java的覆写操作,结合实例形式分析了java属性覆写及super调用父类方法覆写相关操作技巧,需要的朋友可以参考下
    2019-10-10
  • IDEA Error:java: 无效的源发行版: 17错误

    IDEA Error:java: 无效的源发行版: 17错误

    本文主要介绍了IDEA Error:java: 无效的源发行版: 17错误,这个错误是因为您的IDEA编译器不支持Java 17版本,您需要更新您的IDEA编译器或者将您的Java版本降级到IDEA支持的版本,本文就来详细的介绍一下
    2023-08-08
  • SpringBoot中的WebSocketSession原理详解

    SpringBoot中的WebSocketSession原理详解

    这篇文章主要介绍了SpringBoot中的WebSocketSession原理详解,传统的 HTTP 协议是无法支持实时通信的,因为它是一种无状态协议,每次请求都是独立的,无法保持连接。为了解决这个问题,WebSocket 协议被引入,需要的朋友可以参考下
    2023-07-07

最新评论