MyBatis入门【五】输入映射、输出映射

49 篇文章 5 订阅
37 篇文章 1 订阅

输入映射

通过parameterType指定输入参数的类型,类型可以是简单类型、hashmap、pojo包装类型

包装类示例

public class UserQueryVo{
    //在这里包装所需要的查询条件

    //用户查询条件
    private UserCustom getUserCustom(){
        return userCustom;
    }
    public void setUserCustom(UserCustom userCustom){
        this.userCustom = userCustom;
    }

    //可以包装其他的查询条件,订单、商品
}

mapper.xml文件示例:

<!--用户信息综合查询-->
<!--    #{userCustom.sex} :取出pojo包装对象中性别值-->
<select id="findUserList" parameterType="UserQueryVo全路径/别名" resultType="包装类型全路径或别名">
    select * from user where user.id=#{属性.属性(对象组合)} and user.username like '%${属性(单纯的属性,Java基本类型)}%'
</select>

mapper.java:

//用户信息综合查询
public List<UserCustom> findUserList(UserQueryVo userQueryVo) throws Exception;

输出映射

  • 1、resultType
  • 2、resultMap

resultType

使用resultType进行输出映射,只有查询出来的列名和pojo中的属性名一致,该列才可以映射成功。

如果查询出来的列名和pojo中的属性名全部不一致,没有创建pojo对象。
只要查询出来的列名和pojo中的属性有一个一致,就会创建pojo对象

resultMap详解

mybatis中使用resultMap完成高级输出结果映射

resultMap使用方法:

如果查询出来的列名和pojo的属性名不一致,通过定义一个resultMap对列名和pojo属性名之间做一个映射关系

1、定义resultMap

mapper.xml文件中

定义resultMap:

<!-- type:resultMap最终所映射的Java对象类型,可以使用别名 -->
<!-- id:对resultMap的唯一标识、 -->

<resultMap type="user" id="userResultMap">
    <!-- id表示查询结果集中唯一标识  column: 查询出来的列名 property:type指定的pojo类型的属性名   最终resultMap对column和property做一个映射关系(对应关系) -->
    <id column=""  property=""/>
    <!-- result:对普通列名进行映射定义    column: 查询出来的列名 property:type指定的pojo类型的属性名   最终resultMap对column和property做一个映射关系(对应关系) -->
    <result column=""  property=""/>
</resultMap>

mapper.java文件中

<!-- 根据id查询用户信息,使用resultMap -->
public User findUserByIdResultMap(int id) throws Exception;

2、使用resultMap作为statement的输出映射类型

<!-- 使用resultMap进行输出映射-->
<!-- resultMap:指定定义的resultMap的id,如果resultMap在其他的mapper文件中,前边需要加namespace-->
<select id="findUserByIdResultMap" parameterType="int" resultMap="userResultMap">
    SELECT id id_,username username_ FROM USER WHERE id =#{value}
</select>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值