MyBatis总结之输入和输出映射

我们知道mybatis中输入映射和输出映射可以是基本数据类型、hashmap或者pojo的包装类型,这里主要来总结一下pojo包装类型的使用,因为这个在开发中比较常用。

1. 输入映射

  输入映射,是在映射文件中通过parameterType指定输入参数的类型,类型可以是简单类型、hashmap、pojo的包装类型。假设现在有个比较复杂的查询需求:完成用户信息的综合查询,需要传入查询条件很复杂(可能包括用户信息、其它信息,比如商品、订单的),那么我们单纯的传入一个User就不行了,所以首先我们得根据查询条件,自定义一个新的pojo,在这个pojo中包含所有的查询条件。

1.1 定义包装类型pojo

  定义一个UserQueryVo类,将要查询的条件包装进去。这里为了简单起见,就不添加其他的查询条件了,UserQueryVo中就包含一个User,假设复杂的查询条件在User中都已经包含了。

public class UserQueryVo {

//在这里添加所需要的查询条件

//用户查询条件,这里假设一个User就已经够了

private User user;

public User getUser() {

return user;

}

public void setUser(User user) {

this.user = user;

}

}

1.2 配置UserMapper.xml映射文件

  定义好了我们自己的pojo后,需要在UserMap.xml映射文件中配置查询的statement,如下:

<select id="findUserList" parameterType="mybatis.po.UserQueryVo" resultType="mybatis.po.User">

select * from user where sex = #{user.sex} and username like ‘%${user.username}%‘

</select>

  我们看到,输入的parameterType的值是我们自己定义的pojo,输出的是User,当然这里的User也可以换成另一个用户自定义的pojo,包含用户所需要的条件,都行,不仅仅局限为User。然后查询条件使用OGNL表达式,取出UserQueryVo中User的相应属性即可。

  然后别忘了在SqlMapperConfig.xml中配置好这个UserMapper.xml映射文件。

1.3 定义Mapper接口

public interface UserMapper {

//用户信息综合查询

public List<User> findUserList(UserQueryVo userQueryVo) throws Exception;

}

  到此为止,我们就做好了自定义的pojo输入映射了,其实并不是很难

2. 输出映射

  输出映射中同样有很多种对象类型,这里也主要总结一下输出pojo对象。mybatis中的与输出映射有关的resultType就不再叙述了,这里主要总结一下另一个resultMap的使用方法。

  我们知道,通过resultType输出映射的时候,查询出来的列名和pojo中对应的属性名要一致才可以做正确的映射,如果不一致就会映射错误。如果不一致,这就要使用resultMap来映射了。

  假设现在映射文件中有个sql语句:SELECT id id_,username username_ FROM USER WHERE id=#{id},从这个sql语句中可以看出,查询出了id和username两列,但是都起了别名了,也就是说,如果我们现在用resultType去映射到User中的话,肯定会出问题,所以我们现在要定义一个resultMap来做查询结果列与User的属性之间的一个映射。

2.1 定义resultMap

  首先我们要定义一个resultMap,如下:

<resultMap type="user" id="userResultMap">

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

<result column="username_" property="username"/>

</resultMap>

  关于resultMap中的几个属性,简单介绍一下它们的作用:

<resultMap>中的type属性表示 resultMap最终映射的java对象类型。上面用的是别名,如果没有定义别名,需要使用完全限定名

<resultMap>中的id属性是对这个resultMap的唯一标识。

<resultMap>的子标签<id>表示查询结果集中的唯一标识,因为id是主键。

<resultMap>的子标签<result>表示对查询结果集中普通名映射的定义。

子标签中的column属性:表示查询出来的列名

子标签中的property属性:表示上面type指定的pojo类型中的属性名

2.2 配置UserMapper.xml映射文件

<select id="findUserByIdResultMap" parameterType="int" resultMap="userResultMap">

SELECT id id_,username username_ from user where id = #{id}

</select>

2.3 定义Mapper接口

public interface UserMapper {

//根据id查询用户信息,使用resultMap输出

public User findUserByIdResultMap(int id) throws Exception;

}

  在最后的结果中可以看出,打印出的user中只有id和username是有值的,其他都是null,因为我们在sql中只要了这两个属性,所以是正常的。

  

原文地址:https://www.cnblogs.com/fswhq/p/MyBatis.html

时间: 2024-10-05 04:01:35

MyBatis总结之输入和输出映射的相关文章

mybatis 输入、输出映射

一.输入映射 mapper.xml的参数只有一个.可以传参数,基本简单类型,hashmap和javabean (一).Javabean的方法. 需求:通过小说名和作者模糊找书. 1.定义Javabean class  NovelCustom  extends Novel 继承了Novel.一个可以通过什么属性来查询.二.可以在里面加属性.如加上章节名来查询.(表tb_chacter和类Chacter,表中tb_novel_id外键), 或者,将Novel注入到NovelCustom.//priv

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

阅读目录 一:输入映射 二:输出映射 回到顶部 一:输入映射 通过parameterType指定输入参数的类型,类型可以是简单类型.hashmap.pojo的包装类型. 1.1.传递pojo的包装对象 1.1.1.需求描述 完成用户信息的综合查询,需要传入的查询条件可能很复杂(可能包括用户信息,其它信息,比如,商品,订单等等). 1.1.2.定义包装类型的pojo 针对上边的需求,建议使用自定义的包装类型pojo,在包装类型的pojo中将复杂的查询条件包装进去. 包装查询条件的pojo类User

Mybatis学习(4)输入映射、输出映射、动态sql

一.输入映射: 通过parameterType指定输入参数的类型,类型可以是简单类型.hashmap.pojo的包装类型 1) 传递pojo的包装对象 需求是:完成用户信息的综合查询,传入的查询条件复杂:(包括用户信息.其他信息等); 定义包装类型: 用户扩展类: package com.cy.po; /** *用户的扩展类 * @author chengyu * */ public class UserCustom extends User{ } 视图层面的用户包装类型: 1 package

Spring+SpringMVC+MyBatis深入学习及搭建(四)——MyBatis输入映射与输出映射(转发同上)

原地址:http://www.cnblogs.com/shanheyongmu/p/7121556.html 1. 输入映射 通过parameterType指定输入参数的类型,类型可以是简单类型.hashmap.pojo的包装类型. 1.1 #{}与${} #{}实现的是向prepareStatement中的预处理语句设置参数值,sql语句中#{}表示一个占位符即? <select id="findUserById" parameterType="int" r

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

p.p4 { margin: 0.0px 0.0px 0.0px 10.0px; font: 10.5px "PingFang SC" } p.p6 { margin: 0.0px 0.0px 0.0px 21.0px; font: 10.0px "Courier New"; color: #4f76cb } p.p7 { margin: 0.0px 0.0px 0.0px 21.0px; font: 10.0px "Courier New" }

mybatis 输入映射和输出映射

开发步骤: 1)映射文件UserMapper,xml中进行配置 2)接口UserMapper中增加方法 3)测试 输入映射: 需求一.:输入包装类型 UserQueryVo中定义Customer类 Customer继承User类 UserQueryVo <span style="font-family:Courier New;font-size:14px;">public class UserQueryVo { private Customer customer; publ

MyBatis - 输入和输出参数

基础知识 mybatis规定mapp.xml中每一个SQL语句形式上只能有一个@parameterType和一个@resultType 1. 返回值是一个对象的集合,@resultType中只能写该对象的类型,而不是写List<T> 2. 输入参数可以用#{}和${}两种取值方法,两者区别与联系: ① 当传入类型为JDBC基本类型(8种java基本类型+String)时,#{}里面可以写成任意值,${}里面必须写value ② 当传入类型为对象时,两种方式里面都应该写成类中属性名 ③ #{}方

【Mybatis框架】输出映射-resultType与resultMap

输出映射接下来说说有关Mapper.xml配置文件中查询标签中关于返回值类型resultType与resultMap的一些内容 1.resultType使用resultType进行输出映射,只有查询出来的列名和pojo中的属性名一致,该列才可以映射成功.如果查询出来的列名和pojo中的属性名全部不一致,没有创建pojo对象.只要查询出来的列名和pojo中的属性有一个一致,就会创建pojo对象. 1.1输出简单类型1.1.1需求用户信息的综合查询列表总数,通过查询总数和上边用户综合查询列表才可以实

Mybatis中输出映射resultType与resultMap的区别

(原文地址:http://blog.csdn.net/acmman/article/details/46509375) 1.resultType 使用resultType进行输出映射,只有查询出来的列名和pojo(实体bean)中的属性名一致,该列才可以映射成功. 如果查询出来的列名和pojo中的属性名全部不一致,没有创建pojo对象.只要查询出来的列名和pojo中的属性有一个一致,就会创建pojo对象. 1.1输出pojo对象和pojo列表 不管是输出的pojo单个对象还是一个列表(list中