• java-mybaits-00503-延迟加载


    1、什么是延迟加载

    resultMap可以实现高级映射(使用association、collection实现一对一及一对多映射),association、collection具备延迟加载功能。
    需求:
    如果查询订单并且关联查询用户信息。如果先查询订单信息即可满足要求,当我们需要查询用户信息时再查询用户信息。把对用户信息的按需去查询就是延迟加载。
    延迟加载:需要查询关联信息时,使用mybatis延迟加载特性可有效的减少数据库压力,首次查询只查询主要信息,关联信息等用户获取时再加载。大大提高数据库性能,因为查询单表要比关联查询多张表速度要快。

    1.1、打开延迟加载开关

    在mybatis核心配置文件中配置:
    lazyLoadingEnabled、aggressiveLazyLoading
    设置项 描述 允许值 默认值
    lazyLoadingEnabled 全局性设置懒加载。如果设为‘false’,则所有相关联的都会被初始化加载。 true | false false
    aggressiveLazyLoading 当设置为‘true’的时候,懒加载的对象可能被任何懒属性全部加载。否则,每个属性都按需加载。 true | false true
     
    <settings>
        <!--延迟加载的开关-->
           <setting name="lazyLoadingEnabled" value="true"/>
        <!--将积极加载改为消极加载,即按需加载-->
           <setting name="aggressiveLazyLoading" value="false"/>
    </settings>

    1.2、一对一查询延迟加载

    1.2.1、需求

    查询订单信息,关联查询用户信息。
    默认只查询订单信息,当需要查询用户信息时再去查询用户信息。

    1.2.2、Sql语句:

    SELECT  orders.* FROM orders

    1.2.3、定义po类

    在Orders类中加入User属性。 

    1.2.4 Mapper.xml

    <select id="findOrdersList3" resultMap="userordermap2">
        SELECT orders.* FROM orders
    </select>

    1.2.5、定义resultMap

    <!-- 订单信息resultmap -->
    <resultMap type="com.lhx.mybatis.po.Order" id="userordermap2">
        <id property="id" column="id"/>
        <result property="user_id" column="user_id"/>
        <result property="number" column="number"/>
        <association property="user" javaType="com.lhx.mybatis.po.User" select="findUserById" column="user_id"/>
    </resultMap>

    association:

    select="findUserById":指定关联查询sql为findUserById
    如果findUserById不在本mapper中需要前边加namespace
    column="user_id":关联查询时将users_id列的值传入findUserById
    最后将关联查询结果映射至com.lhx.mybatis.po.User。
    关联查询的sql理解为:
    SELECT orders.*,
       (SELECT username FROM USER WHERE orders.user_id = user.id)username,
       (SELECT sex FROM USER WHERE orders.user_id = user.id)sex
        FROM orders

    1.2.6、Mapper接口:

    public List<Orders> findOrdersList3() throws Exception;

    1.2.7、测试:

    public void testfindOrdersList3()throws Exception{
           //获取session
           SqlSession session = sqlSessionFactory.openSession();
           //获限mapper接口实例
           UserMapper userMapper = session.getMapper(UserMapper.class);
           //查询订单信息
           List<Orders> list = userMapper.findOrdersList3();
           System.out.println(list);
           //开始加载,通过orders.getUser方法进行加载
        for(Orders orders:list){
               System.out.println(orders.getUser());
           }
           //关闭session
           session.close();
        }

    测试思路:

    1、执行上边mapper方法(findOrdersUserLazyLoading),内部去调用cn.itcast.mybatis.mapper.OrdersMapperCustom中的findOrdersUserLazyLoading只查询orders信息(单表)。
     
    2、在程序中去遍历上一步骤查询出的List<Orders>,当我们调用Orders中的getUser方法时,开始进行延迟加载。
     
    3、延迟加载,去调用UserMapper.xml中findUserbyId这个方法获取用户信息。

    1.1.2.8 延迟加载的思考

    不使用mybatis提供的association及collection中的延迟加载功能,如何实现延迟加载??
     
    实现方法:
    针对订单和用户两个表定义两个mapper方法。
    1、订单查询mapper方法
    2、根据用户id查询用户信息mapper方法
    默认使用订单查询mapper方法只查询订单信息。
    当需要关联查询用户信息时再调用根据用户id查询用户信息mapper方法查询用户信息。
     
     实现思路:
    先去查询第一个mapper方法,获取订单信息列表
    在程序中(service),按需去调用第二个mapper方法去查询用户信息。
     
    总之:
    使用延迟加载方法,先去查询简单的sql(最好单表,也可以关联查询),再去按需要加载关联查询的其它信息。

    1.3  一对多延迟加载

    一对多延迟加载的方法同一对一延迟加载,在collection标签中配置select内容。
    本部分内容自学。 

    1.4  延迟加载小结

    作用:
             当需要查询关联信息时再去数据库查询,默认不去关联查询,提高数据库性能。
             只有使用resultMap支持延迟加载设置。
    场合:
             当只有部分记录需要关联查询其它信息时,此时可按需延迟加载,需要关联查询时再向数据库发出sql,以提高数据库性能。
             当全部需要关联查询信息时,此时不用延迟加载,直接将关联查询信息全部返回即可,可使用resultType或resultMap完成映射。
      
  • 相关阅读:
    Linq的一些常见Demo
    有一名员工发现日历已经7天没有翻了,于是他连着翻了7页,7天的总和刚好是138,问这一天是几号?
    20块钱,1块钱1瓶,两个空瓶子可以换一瓶,问最多可以喝几瓶?
    【转】Java编程之字符集问题研究
    Reset / Validate Buffer
    Article Master Data Deviation
    STAD Parameters
    Linux11.2 MySQL常用命令
    Linux11.1 设置更改Mysql的root密码及连接mysql
    Linux5.10 告警系统
  • 原文地址:https://www.cnblogs.com/bjlhx/p/6854390.html
Copyright © 2020-2023  润新知