Mybatis第七篇【resultMap、resultType、延迟加载】

resultMap

有的时候,咱们看别的映射文件,可能看不到如下这么一段代码:css

<resultMap id="userListResultMap" type="user" >
        <!-- 列名 id_,username_,birthday_ id:要映射结果集的惟 一标识 ,称为主键 column:结果集的列名 property:type指定的哪一个属性中 -->
         <id column="id_" property="id"/>
         <!-- result就是普通列的映射配置 -->
         <result column="username_" property="username"/>
         <result column="birthday_" property="birthday"/>

    </resultMap>

由于,若是咱们的数据表的字段和JavaBean的属性名称是相同时,咱们就不用上面那段代码了。Mybatis会自动帮咱们把返回的结果进行封装成JavaBean前端

那当咱们数据表的字段和JavaBean的属性名称不是相同时,咱们就须要使用resultMap,也就是上面那段代码java

resultMap和resultType区别

resultType :指定输出结果的类型(pojo、简单类型、hashmap..),将sql查询结果映射为java对象 。sql

  • 使用resultType注意:sql查询的列名要和resultType指定pojo的属性名相同,指定相同 属性方可映射成功,若是sql查询的列名要和resultType指定pojo的属性名所有不相同,list中没法建立pojo对象的。

resultMap:将sql查询结果映射为java对象。数据库

  • 若是sql查询列名和最终要映射的pojo的属性名不一致,使用resultMap将列名和pojo的属性名作一个对应关系 (列名和属性名映射配置)

使用resultMap

<resultMap id="userListResultMap" type="user" >
        <!-- 列名 id_,username_,birthday_ id:要映射结果集的惟 一标识 ,称为主键 column:结果集的列名 property:type指定的哪一个属性中 -->
         <id column="id_" property="id"/>
         <!-- result就是普通列的映射配置 -->
         <result column="username_" property="username"/>
         <result column="birthday_" property="birthday"/>

    </resultMap>

这里写图片描述

这里写图片描述


resultType和resultMap用法总结

resultType:markdown

  • 做用:mybatis

    • 将查询结果按照sql列名pojo属性名一致性映射到pojo中。
  • 场合:app

    • 常见一些明细记录的展现,将关联查询信息所有展现在页面时,此时可直接使用resultType将每一条记录映射到pojo中,在前端页面遍历list(list中是pojo)便可。

resultMap:性能

  • 使用association和collection完成一对一和一对多高级映射。

association:测试

  • 做用:
    • 将关联查询信息映射到一个pojo类中。
  • 场合:
    • 为了方便获取关联信息可使用association将关联订单映射为pojo,好比:查询订单及关联用户信息。

collection:

  • 做用:
    • 将关联查询信息映射到一个list集合中。
  • 场合:
    • 为了方便获取关联信息可使用collection将关联信息映射到list集合中,好比:查询用户权限范围模块和功能,可以使用collection将模块和功能列表映射到list中。

Collection在前面好像并无用过,下面就看一下它的用法:

Order与OrderDetails关系

package cn.itcast.mybatis.po; import java.io.Serializable; import java.util.Date; import java.util.List; public class Orders implements Serializable { private Integer id; private Integer userId; private String number; private Date createtime; private String note; //关联用户信息 private User user; //订单明细 private List<Orderdetail> orderdetails; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public Integer getUserId() { return userId; } public void setUserId(Integer userId) { this.userId = userId; } public String getNumber() { return number; } public void setNumber(String number) { this.number = number == null ? null : number.trim(); } public Date getCreatetime() { return createtime; } public void setCreatetime(Date createtime) { this.createtime = createtime; } public String getNote() { return note; } public void setNote(String note) { this.note = note == null ? null : note.trim(); } public User getUser() { return user; } public void setUser(User user) { this.user = user; } public List<Orderdetail> getOrderdetails() { return orderdetails; } public void setOrderdetails(List<Orderdetail> orderdetails) { this.orderdetails = orderdetails; } } 

SQL语句

<!-- 一对多查询使用reusltMap完成 查询订单关联查询订单明细 -->
     <select id="findOrderAndOrderDetails" resultMap="orderAndOrderDetails" >
            SELECT 
      orders.*,
      user.username,
      user.sex ,
      orderdetail.id orderdetail_id,
      orderdetail.items_num,
      orderdetail.items_id
    FROM
      orders,
      USER,
      orderdetail
    WHERE orders.user_id = user.id  AND orders.id = orderdetail.orders_id
     </select>

resultMap

<!-- 一对多,查询订单及订单明细 -->
    <resultMap type="orders" id="orderAndOrderDetails" extends="ordersUserResultMap">
        <!-- 映射订单信息,和用户信息,这里使用继承ordersUserResultMap -->

        <!-- 映射订单明细信息 property:要将关联信息映射到orders的哪一个属性中 ofType:集合中pojo的类型 -->
        <collection property="orderdetails" ofType="cn.itcast.mybatis.po.Orderdetail">
            <!-- id:关联信息订单明细的惟 一标识 property:Orderdetail的属性名 -->
            <id column="orderdetail_id" property="id"/>
            <result column="items_num" property="itemsNum"/>
            <result column="items_id" property="itemsId"/>
        </collection>

    </resultMap>

延迟加载

在进行数据查询时,为了提升数据库查询性能,尽可能使用单表查询,由于单表查询比多表关联查询速度要快。

若是查询单表就能够知足需求,一开始先查询单表,当须要关联信息时,再关联查询,当须要关联信息再查询这个叫延迟加载

在Mybatis中延迟加载就是在resultMap中配置具体的延迟加载..

这里写图片描述

在Mybatis的文件中配置全局延迟加载

<!-- 全局配置参数 -->
    <settings>
        <!-- 延迟加载总开关 -->
        <setting name="lazyLoadingEnabled" value="true" />  
        <!-- 设置按需加载 -->
        <setting name="aggressiveLazyLoading" value="false" />
    </settings>

延迟加载测试

当须要用户时调用 Orders类中的getUser()方法执行延迟加载 ,向数据库发出sql。

因为是对User进行延迟加载,那么咱们只要查询Orders相关的信息便可了

<!-- 一对一查询延迟加载 开始只查询订单,对用户信息进行延迟加载 -->
     <select id="findOrderUserListLazyLoading" resultMap="orderCustomLazyLoading">
         SELECT 
          orders.*
        FROM
          orders
     </select>

使用resultMap来配置延迟加载

<!-- 一对一查询延迟加载 的配置 -->
    <resultMap type="orders" id="orderCustomLazyLoading">
        <!-- 完成了订单信息的映射配置 -->
        <!-- id:订单关联用户查询的惟 一 标识 -->
        <id column="id" property="id" />
        <result column="user_id" property="userId" />
        <result column="number" property="number" />
        <result column="createtime" property="createtime" />
        <result column="note" property="note" />
        <!-- 配置用户信息的延迟加载 select:延迟加载执行的sql所在的statement的id,若是不在同一个namespace须要加namespace sql:根据用户id查询用户信息【column就是参数】 column:关联查询的列 property:将关联查询的用户信息设置到Orders的哪一个属性 -->


        <!--当须要user数据的时候,它就会把column所指定的user_id传递过去给cn.itcast.mybatis.mapper.UserMapper.findUserById做为参数来查询数据-->
        <association property="user" select="cn.itcast.mybatis.mapper.UserMapper.findUserById" column="user_id"></association>

    </resultMap>

这里写图片描述

相关文章
相关标签/搜索