目录


前言

通过 paramterType 指定输入参数类型,类型可以是 简单类型pojohashmap ,这里只讲究相对较难的 pojo ;


输入映射 — — 传递 pojo 包装类型 (复杂查询 )

需求 :完成用户信息的综合查询,需要 传入查询条件(可能包括用户信息、其他信息,比如:商品信息、订单信息) ;

例子:查询所有买了 i7-4710 cpu 电脑的用户信息 ;

针对上面需求,建议使用自定义的 包装类型 pojo ,在包装类型的 pojo 中将复杂的 查询条件 包装起来 ;将需要查询的条件,作为包装类型的属性,封装进去 ;


后面学到逆向工程的时候,我们就不再需要手写 User 这样的类,直接使用工具根据数据库的字段,自动生成 ;

假如,生成的类,我们需要做一些改动,我们推荐写一个增强类继承生成的类,在增强类中改动 ;

事例代码

public class UserStrengthen extends User {
//.... 要增强的内容 }

说明:其实复杂查询,也很好理解,就是当查询条件比较复杂的时候,我们需要对其进行封装,这里我们将复杂条件封装到 UserQueryVo 中 ,需要对该类,设置 get 、set 方法,为了mybatis 使用反射获取其属性 ;

UserQueryVo 类 :

/**
* 封装复杂查询条件
* @author An
*/
public class UserQueryVo { /**
* 封装用户条件
*/
private UserStrengthen userStrengthen ; public UserStrengthen getUserStrengthen() {
return userStrengthen;
} public void setUserStrengthen(UserStrengthen userStrengthen) {
this.userStrengthen = userStrengthen;
} //.... 封装其他条件,比如商品订单
}

在映射文件中,写出 sql 语句,参数类型就是我们封装的 UserQueryVo 类 ;

   <!--复杂查询-->
<select id="findUsersByVo" parameterType="userQueryVo" resultType="userStrengthen">
SELECT * from user where sex = #{userStrengthen.sex} and name like '%${userStrengthen.name}%'
</select>

mapper 代理接口中,构建出方法:

/**
* 复杂查询
* @param userQueryVo
* @return
* @throws Exception
*/
public List<UserStrengthen> findUsersByVo(UserQueryVo userQueryVo) throws Exception ;



输出映射 — — resultType

输出映射可以,可以输出 简单类型pojo 对象pojo 列表hashmap

其中输出 pojo 对象 可改为输出 hashmap,其中字段名是 key ,名字值是 value ;输出 pojo 列表 可改为输出 List<HashMap> ;

说明:在使用 resultType 进行输出映射的时候,只要查询出来的列名pojo 对象的属性名一致的时候,该列结果才会得到映射; 如果查询结果的列,没有一列 得到映射,则不会创建 pojo 对象,但是 只要有一列 得到映射,就会创建 pojo 对象


输出映射 — — resultMap

mybatis 中完成高级输出结果映射的东西,完成 一对多、多对多、多对一 ;(以后会讲)

简单的使用场景

如果查询出来的列名pojo 对象的属性名不一致,那么可以通过定义一个 resultMap 对列名和属性名之间,进行映射 ;

  1. 在映射关系中定义 resultMap

    <!--定义一个 resultMap-->
    <!--
    id 是 resultMap 的唯一标识 ;
    type 是 resultMap 最终要将查询的列名和谁进行映射的类
    -->
    <resultMap id="userMap" type="user">
    <!--对 结果集中的唯一标识,例如主键,使用 id标签 进行映射-->
    <id column="id_" property="id"></id>
    <!--其他属性使用 result 进行映射-->
    <result column="sex_" property="sex"></result>
    </resultMap>
  2. 使用 resultMap 作为 statement 的输出映射类型 ;

    <!--如果 map 定义在其他映射关系文件中,则需要加上命名空间-->
    <select id="findUserByMap" parameterType="int" resultMap="userMap">
    SELECT id id_,sex sex_ from user where id = #{id}
    </select>
  3. mapper 接口中,定义方法,方法的返回值,是 **resultMap 中的 type 类型 ;

    public User findUserByMap(int id) throws Exception ;

(七)mybatis 的输入映射与输出映射的更多相关文章

  1. 【mybatis深度历险系列】mybatis中的输入映射和输出映射

    在前面的博文中,小编介绍了mybatis的框架原理以及入门程序,还有mybatis中开发到的两种方法,原始开发dao的方法和mapper代理方法,今天博文,我们来继续学习mybatis中的相关知识,随 ...

  2. Mybatis学习总结(四)——输入映射和输出映射

    在前面几篇文章的例子中也可以看到mybatis中输入映射和输出映射的身影,但是没有系统的总结一下,这篇博客主要对这两个东东做一个总结.我们知道mybatis中输入映射和输出映射可以是基本数据类型.ha ...

  3. MyBatis入门(二)—— 输入映射和输出映射、动态sql、关联查询

    一.输入映射和输出映射 1. parameterType(输入类型) 1.1 传递简单类型 <select id="getUserById" parameterType=&q ...

  4. 【MyBatis学习06】输入映射和输出映射

    在前面几篇博文的例子中也可以看到mybatis中输入映射和输出映射的身影,但是没有系统的总结一下,这篇博客主要对这两个东东做一个总结.我们知道mybatis中输入映射和输出映射可以是基本数据类型.ha ...

  5. mybatis入门基础(四)----输入映射和输出映射

    一:输入映射 通过parameterType指定输入参数的类型,类型可以是简单类型.hashmap.pojo的包装类型. 1.1.传递pojo的包装对象 1.1.1.需求描述 完成用户信息的综合查询, ...

  6. Spring+SpringMVC+MyBatis深入学习及搭建(四)——MyBatis输入映射与输出映射

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6878529.html 前面有讲到Spring+SpringMVC+MyBatis深入学习及搭建(三)——My ...

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

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

  8. mybatis进阶--输入映射和输出映射

    我们知道,mapper.xml是我们配置操作数据库的sql语句的地方.其中每个sql语句对应着一个方法,每个方法都有自己的输入输出参数类型.那么这些类型都是怎么配置的呢?今天我们来一起学习下. 输入映 ...

  9. mybatis进阶--mapper输入映射和输出映射

    我们知道,mapper.xml是我们配置操作数据库的sql语句的地方.其中每个sql语句对应着一个方法,每个方法都有自己的输入输出参数类型.那么这些类型都是怎么配置的呢?今天我们来一起学习下. 输入映 ...

随机推荐

  1. 串结构练习——字符串连接(SDUT 2124)

    Problem Description 给定两个字符串string1和string2,将字符串string2连接在string1的后面,并将连接后的字符串输出. 连接后字符串长度不超过110. Inp ...

  2. 自动化测试报告浅谈之ExtentReports

    我们在进行自动化测试时,往往需要有相应的测试报告,比如junit,testng,reportng等等,有会有自带的测试报告,那为什么我要在这边提ExtentReports?首先,我们来看看其它几种测试 ...

  3. webpack - 优化阻塞渲染的css

    随着浏览器的日新月异,网页的性能和速度越来越好,并且对于用户体验来说也越来越重要. 现在有很多优化页面的办法,比如:静态资源的合并和压缩,code splitting,DNS预读取等等. 本文介绍的是 ...

  4. cs配合msf批量探测内网MS17-010漏洞

    第一步 Cobalt strike 派生 shell 给 MSF(前提有个beacon shell) 第二步 选择要派生的beacon,右键-->增加会话,选择刚刚配置的foreign监听器 第 ...

  5. JS合并多个数组去重算法

    var arr1 = ['a','b']; var arr2 = ['a','c','d']; var arr3 = [1,'d',undefined,true,null]; //合并两个数组,去重 ...

  6. 最全的tcpdump使用详解

    简介 用简单的话来定义tcpdump,就是:dump the traffic on a network,根据使用者的定义对网络上的数据包进行截获的包分析工具. tcpdump可以将网络中传送的数据包的 ...

  7. LeetCode —— 单词接龙(Python)

    使用字典,降低查找的复杂度.使用list会超时. class Solution: def nextWordsList(self, word, wordDict): res_list = [] for ...

  8. linux下的什么工具能将DVI文件转换成PostScript文件?

    答: dvips,此工具能将由Latex或Tex生成的DVI文件转换成PostScript文件,官网在此

  9. 阶段5 3.微服务项目【学成在线】_day02 CMS前端开发_08-vuejs研究-vuejs基础-v-if和v-for指令

    1.2.4 v-if和v-for <!DOCTYPE html> <html lang="en"> <head> <meta charse ...

  10. 阶段5 3.微服务项目【学成在线】_day02 CMS前端开发_21-CMS前端页面查询开发-Api调用

    在api里面定义js方法获取服务端的数据 把home模块的下的home.js文件复制到api的目录下改名叫做cms.js 复制过来 默认的代码 实际上引用的是base下的api/public.js文件 ...