前言

MyBatis作为一款持久层的框架,从最初的ibatis更名,经过五六年的发展更新,如今已经更新到了3.4.5版本。MyBatis通过简单的xml或注解配置,就能将接口和Java的对象映射成数据库的记录,避免了很多的手动配置,现已被越来越多的开发者使用。

刚开始使用的话,可能会有很多困惑:明明传递了值,为什么传递不到xml中?到底该用resultMap还是用resultType?如果我想返回String、Map、List等等,该如何写?在写了这么多MyBatis代码后,我总结了一下项目中常见的几种,供大家参考,如果想进一步了解,请参考官方文档:http://www.mybatis.org/mybatis-3/zh/index.html

干货图

接口和xml对应图表

高清图:http://img.blog.csdn.net/20170831064012748

干货图描述

在业务逻辑中,最常用的当属查询了,传递的值多样化,需要的返回值样式也不一样,但是等写好了回来再看时,发现也就那几种。

1. 参数类型:String,返回值类型:List<对象>

public List<Student> getStudentByName(@Param(value="name") String name);

<select id="getStudentByName" parameterType="java.lang.String" resultMap="BaseResultMap">

select * from xxx where stu_name = #{name}

</select>

2. 参数类型:Map<String, Object>,返回值类型:List<对象>

public List<Student> getStudents(Map<String, Object> params);

<select id="getStudents" parameterType="java.util.Map" resultMap="BaseResultMap">

select * from xxx where stu_name = #{name}

</select>

3. 参数类型:String,返回值类型:对象

public Student getStudentById(@Param(value="id") String id);

<select id="getStudentById" resultMap="BaseResultMap">

select * from xxx where id = #{id}

</select>

4. 参数类型:String,返回值类型:String

String queryUserIdByThirdParty(@Param("openId") String openId);

<select id="queryUserIdByThirdParty" resultType="java.lang.String">

select user_id from sys_users where open_id=#{openId}

</select>

5. 参数类型:String,返回值类型:List<String>

List<String> getUserIds(@Param("tenantId") String tenantId);

<select id="getUserIds" resultType="java.lang.String">

select id from sys_users where tenant_id = #{tenantId};

</select>

6. 参数类型:String,返回值类型:Map<String, Object>

Map<String, Object> getChargeSum(@Param(value = "uid") String uid);

<select id="getChargeSum" resultType="java.util.Map" parameterType="java.lang.String">

select sum(transaction_amount) as chargeSum from xxx where id = #{uid}

</select>

7. 参数类型:String,返回值类型:List<Map<String, Object>>

List<Map<String,Object>> getReadsNum(@Param(value = "account") String account);

<select id="getReadsNum" resultType="java.util.Map">

select * from xxxx where mw_account = #{account}

</select>

8. 参数类型:String,返回值类型:int

int deleteById(@Param(value = "id") String id, @Param(value = "uid") String uid);

<delete id="deleteById" parameterType="java.lang.String">

delete from xxxx where id = #{id} and create_by = #{uid};

</delete>

9. 参数类型:void,返回值类型:int

int deleteById(@Param(value = "id") String id, @Param(value = "uid") String uid);

<delete id="deleteById">

delete from xxxx where id = #{id} and create_by = #{uid};

</delete>

10. 参数类型:对象,返回值类型:int

int updateStuInfo(StudentInfo studentInfo);

<update id="updateStuInfo" parameterType="xx.xxx.xxxx.StudentInfo">

update xxxx set stu_name = #{stuName}...

where id = #{id}

</update>

说明

1. 接口中的@Param注解指的是 org.apache.ibatis.annotations.Param,使用这个注解就相当于给一个参数起一个别名,在xml中可以直接使用这个别名。如果不使用这个注解,需要保证参数的名称和xml中property配置相同。

<dependency>

<groupId>org.mybatis</groupId>

<artifactId>mybatis</artifactId>

<version>3.4.5</version>

</dependency>

2. 在查询中,parameterType有时是可选的,但是resultMap或者resultType基本上都是需要的。

3. BaseResultMap指的是数据表和对象的映射关系,如:

<resultMap id="BaseResultMap" type="xx.xxx.xxxx.StudentInfo">

<id column="id_" jdbcType="VARCHAR" property="id" />

...

</resultMap>

4. 如果使用IDEA开发工具,可以下载Free MyBatis plugin插件,可以在xml和接口直接进行点击跟踪。

这次没有涉及到批量插入和复杂点继承关系查询,后续会更新。

mybatis 基础的更多相关文章

  1. myBatis 基础测试 表关联关系配置 集合 测试

    myBatis 基础测试 表关联关系配置 集合 测试 测试myelipse项目源码 sql 下载 http://download.csdn.net/detail/liangrui1988/599388 ...

  2. JAVA之Mybatis基础入门--框架搭建与简单查询

    JAVA中,操作数据库有JDBC.hibernate.Mybatis等技术,今天整理了下,来讲一讲下Mybatis.也为自己整理下文档: hibernate是一个完全的ORM框架,是完全面向对象的.但 ...

  3. MyBatis基础入门《二十》动态SQL(foreach)

    MyBatis基础入门<二十>动态SQL(foreach) 1. 迭代一个集合,通常用于in条件 2. 属性 > item > index > collection : ...

  4. mybatis基础系列(四)——关联查询、延迟加载、一级缓存与二级缓存

    关本文是Mybatis基础系列的第四篇文章,点击下面链接可以查看前面的文章: mybatis基础系列(三)——动态sql mybatis基础系列(二)——基础语法.别名.输入映射.输出映射 mybat ...

  5. mybatis基础系列(三)——动态sql

    本文是Mybatis基础系列的第三篇文章,点击下面链接可以查看前面的文章: mybatis基础系列(二)--基础语法.别名.输入映射.输出映射 mybatis基础系列(一)--mybatis入门 动态 ...

  6. mybatis基础系列(二)——基础语法、别名、输入映射、输出映射

    增删改查 mapper根节点及其子节点 mybatis框架需要读取映射文件创建会话工厂,映射文件是以<mapper>作为根节点,在根节点中支持9个元素,分别为insert.update.d ...

  7. mybatis基础系列(一)——mybatis入门

    好久不发博客了,写博文的一个好处是能让心静下来,整理下之前学习过的一些知识一起分享,大神路过~ mybatis简介 MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射. ...

  8. MyBatis基础入门《十九》动态SQL(set,trim)

    MyBatis基础入门<十九>动态SQL(set,trim) 描述: 1. 问题 : 更新用户表数据时,若某个参数为null时,会导致更新错误 2. 分析: 正确结果: 若某个参数为nul ...

  9. MyBatis基础入门《十八》动态SQL(if-where)

    MyBatis基础入门<十八>动态SQL(if-where) 描述: 代码是在<MyBatis基础入门<十七>动态SQL>基础上进行改造的,不再贴所有代码,仅贴改动 ...

  10. MyBatis基础入门《十七》动态SQL

    MyBatis基础入门<十七>动态SQL 描述: >> 完成多条件查询等逻辑实现 >> 用于实现动态SQL的元素主要有: > if > trim > ...

随机推荐

  1. mysql timeout

    (待更新整理) 因为最近遇到一些超时的问题,正好就把所有的timeout参数都理一遍,首先数据库里查一下看有哪些超时: root@localhost : test 12:55:50> show ...

  2. 选择排序-Python与PHP实现版

    选择排序Python实现 import random # 生成待排序数组 a=[random.randint(1,999) for x in range(0,36)] # 选择排序 def selec ...

  3. 9. 使用ZooKeeper Java API编程

    ZooKeeper是用Java开发的,3.4.6版本的Java API文档可以在http://zookeeper.apache.org/doc/r3.4.6/api/index.html上找到. Ti ...

  4. SQL Server 基本操作之三种增加法

    前言: 数据库操作避免不了对数据的操作,操作方法大同小异,万变不离其宗,今就写一下各种花式操作的根本增删改查四种操作,今天我们就来说一下增加操作的三种方法 正文: 增加操作是对数据库进行数据行的添加, ...

  5. CVE-2017-11882漏洞 Msf利用复现

    中午时候收到了推送的漏洞预警,在网上搜索相关信息看到很多大牛已经开发出生成doc文档的脚本和msf的poc,本文记录CVE-2017-11882 漏洞在 Msf下的利用. 0x00 漏洞简介 2017 ...

  6. 今天用node的cheerio模块做了个某乎的爬虫

        一时兴起,想做个爬虫,经过各种深思熟虑,最后选择了某乎,毕竟现在某乎的数据质量还是挺高的.说干就干 打开某乎首页,随便搜索了一串关键字,相关的问题和答案就展现在眼前,我就思考怎么把这些搜索结果 ...

  7. git使用(上)-----基本的方法

    git应该是一项必须要掌握的工具.先简述它和SVN的区别 SVN是集中式版本控制系统,版本库是集中放在中央服务器的,而干活的时候,用的都是自己的电脑,所以首先要从中央服务器哪里得到最新的版本,然后干活 ...

  8. 漫谈 SLAM 技术(上)

    欢迎大家前往腾讯云社区,获取更多腾讯海量技术实践干货哦~ 作者:解洪文 导语 随着最近几年机器人.无人机.无人驾驶.VR/AR的火爆,SLAM技术也为大家熟知,被认为是这些领域的关键技术之一.本文对S ...

  9. canvas画一个时钟

    效果图如下 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF ...

  10. Solidity教程系列1 - 类型介绍

    现在的Solidity中文文档,要么翻译的太烂,要么太旧,决定重新翻译下,再加上代码事例讲解. 写在前面 Solidity是以太坊智能合约编程语言,阅读本文前,你应该对以太坊.智能合约有所了解, 如果 ...