zoukankan      html  css  js  c++  java
  • Mybatis第七篇【resultMap、resultType、延迟加载】

    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>

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

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

    resultMap和resultType区别

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

    • 使用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:

    • 作用:

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

      • 常见一些明细记录的展示,将关联查询信息全部展示在页面时,此时可直接使用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>

    这里写图片描述


  • 相关阅读:
    #cat ora11g_ora_.trc
    Vue学习之路3-浅析Vue-cli搭建项目后的目录结构
    Vue学习之路2-项目初搭建
    Vue学习之路1-集成环境安装
    laravel中建立公共视图的方法
    Windows下Laravel5.5 的 Homestead 开发环境部署
    技术好文推荐
    中文文案排版指北
    消息队列的使用
    Laravel 验证中文本地化
  • 原文地址:https://www.cnblogs.com/zhong-fucheng/p/7554350.html
Copyright © 2011-2022 走看看