• mybatis中resultMap和resultType的区别


    总结

    基本映射 :(resultType)使用resultType进行输出映射,只有查询出来的列名和pojo中的属性名一致,该列才可以映射成功。(数据库,实体,查询字段,这些全部都得一一对应)高级映射 :(resultMap) 如果查询出来的列名和pojo的属性名不一致,通过定义一个resultMap对列名和pojo属性名之间作一个映射关系。(高级映射,字段名称可以不一致,通过映射来实现

    resultType和resultMap功能类似 ,都是返回对象信息 ,但是resultMap要更强大一些 ,可自定义。因为resultMap要配置一下,表和类的一一对应关系,所以说就算你的字段名和你的实体类的属性名不一样也没关系,都会给你映射出来,但是,resultType就比较鸡肋了,必须字段名一样,比如说 cId和c_id 这种的都不能映射 。下面介绍几个常用的映射关系:

    单表查询: resultMap:当使用resultMap做SQL语句返回结果类型处理时,通常需要在mapper.xml中定义resultMap进行pojo和相应表字段的对应。
    订单查询关联用户的resultMap
    将整个查询的结果映射到cn.itcast.mybatis.po.Orders中

    1. "cn.itcast.mybatis.po.Orders" id="OrdersUserResultMap">
    2. "id" property="id"/>
    3. "user_id" property="userId"/>
    4. "number" property="number"/>
    5. "createtime" property="createtime"/>
    6. "note" property="note"/>

    关联查询(一对一):resultMap对于一对一表连接的处理方式通常为在主表的pojo中添加嵌套另一个表的pojo,然后在mapper.xml中采用association节点元素进行对另一个表的连接处理。例如
    订单查询关联用户的resultMap
    将整个查询的结果映射到cn.itcast.mybatis.po.Orders中

    1. "cn.itcast.mybatis.po.Orders" id="OrdersUserResultMap">
    2. "id" property="id"/>
    3. "user_id" property="userId"/>
    4. "number" property="number"/>
    5. "createtime" property="createtime"/>
    6. "note" property=note/>
    7. "user" javaType="cn.itcast.mybatis.po.User">
    8. "user_id" property="id"/>
    9. "username" property="username"/>
    10. "sex" property="sex"/>
    11. "address" property="address"/>

    关联查询(一对多):resultMap的处理方式为在订单表数据的pojo中添加一个list,list中为订单明细表的属性,在mapper.xml中采用如下的处理方式:
    订单及订单明细的resultMap
    使用extends继承,不用在中配置订单信息和用户信息的映射

    1. "cn.itcast.mybatis.po.Orders" id="OrdersAndOrderDetailResultMap" extends="OrdersUserResultMap">
    2. "orderdetails" ofType="cn.itcast.mybatis.po.Orderdetail">
    3. "orderdetail_id" property="id"/>
    4. "items_id" property="itemsId"/>
    5. "items_num" property="itemsNum"/>
    6. "orders_id" property="ordersId"/>

     

    association:
    作用:
    将关联查询信息映射到一个pojo对象中

    场合:
    为了方便查询关联查询可以使用assocation将关联查询信息映射为用户对象的pojo属性中。

    比如:查询订单及关联用户信息
    使用resultType无法查询结果映射到pojo对象的pojo属性中,根据对结构集查询遍历的需要选择使用resultType还是resultMap。

    collection:
    作用:
    将关联查询信息映射到一个list集合中。
    场合:
    为了方便查询遍历关联信息可以使用cellection将关联信息映射到list集合中。
    比如:
    查询用户权限范围模块及模块下的菜单,可使用collection将模块映射到模块list中将菜单列表映射到模块对象的菜单list属性中,这样做的目的也是方便对查询结果集进行遍历如果使用resultType无法将查询结果映射到list集合中

  • 相关阅读:
    STM32 PWM配置及呼吸灯
    高等工程数学 —— 第一章 (1)距离与范数
    Scala基础【正则表达式、框架式开发原则】
    【Java】反射 之 获取继承关系
    【C#/.NET】使用Automapper映射record类型
    Nodejs和ES6的模块化 import ,export
    计算机网络-网络文件共享协议
    【牛客-剑指offer-数据结构篇】JZ23 链表中环的入口结点 两种实现 Java实现
    R语言深度学习-4-识别异常数据(无监督学习/自动编码器)
    【附源码】Python计算机毕业设计师生信息交流指导系统
  • 原文地址:https://blog.csdn.net/m0_72252418/article/details/139677578