1、什么是延迟加载

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

1.1、打开延迟加载开关

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

1.2、一对一查询延迟加载

1.2.1、需求

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

1.2.2、Sql语句:

  1. SELECT orders.* FROM orders

1.2.3、定义po类

在Orders类中加入User属性。 

1.2.4 Mapper.xml

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

1.2.5、定义resultMap

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

association:

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

1.2.6、Mapper接口:

  1. public List<Orders> findOrdersList3() throws Exception;

1.2.7、测试:

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

测试思路:

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完成映射。
  

java-mybaits-00503-延迟加载的更多相关文章

  1. java mybaits 调用存储过程

    @Override public BaseResultMessage saveOrderConfirm(String billNo) { BaseResultMessage rm = Utils.re ...

  2. Mybaits 源码解析 (三)----- Mapper接口底层原理(为什么Mapper不用写实现类就能访问到数据库?)

    上一篇我们讲解到mapperElement方法用来解析mapper,我们这篇文章具体来看看mapper.xml的解析过程 mappers配置方式 mappers 标签下有许多 mapper 标签,每一 ...

  3. java面试--360

    1题执行以下程序后的输出结果是()public class Test {public static void main(String[] args) {StringBuffer a = new Str ...

  4. hibernate延迟加载org.hibernate.LazyInitializationException: failed to lazily initialize a collection of role: com.javakc.hibernate.onetomany.entity.DeptEntity.emp, could not initialize proxy - no Session

    public static void main(String[] args) {  DeptEntity dept = getDept("402882e762ae888d0162ae888e ...

  5. 精尽MyBatis源码分析 - SQL执行过程(四)之延迟加载

    该系列文档是本人在学习 Mybatis 的源码过程中总结下来的,可能对读者不太友好,请结合我的源码注释(Mybatis源码分析 GitHub 地址.Mybatis-Spring 源码分析 GitHub ...

  6. 蚂蚁金服寒泉子:JVM源码分析之临门一脚的OutOfMemoryError完全解读

    ➠更多技术干货请戳:听云博客 概述 OutOfMemoryError,说的是java.lang.OutOfMemoryError,是JDK里自带的异常,顾名思义,说的就是内存溢出,当我们的系统内存严重 ...

  7. JVM源码分析之临门一脚的OutOfMemoryError完全解读

    概述 OutOfMemoryError,说的是java.lang.OutOfMemoryError,是JDK里自带的异常,顾名思义,说的就是内存溢出,当我们的系统内存严重不足的时候就会抛出这个异常(P ...

  8. 精尽MyBatis源码分析 - MyBatis 的 SQL 执行过程(一)之 Executor

    该系列文档是本人在学习 Mybatis 的源码过程中总结下来的,可能对读者不太友好,请结合我的源码注释(Mybatis源码分析 GitHub 地址.Mybatis-Spring 源码分析 GitHub ...

  9. 精尽MyBatis源码分析 - SQL执行过程(二)之 StatementHandler

    该系列文档是本人在学习 Mybatis 的源码过程中总结下来的,可能对读者不太友好,请结合我的源码注释(Mybatis源码分析 GitHub 地址.Mybatis-Spring 源码分析 GitHub ...

  10. 精尽MyBatis源码分析 - SQL执行过程(三)之 ResultSetHandler

    该系列文档是本人在学习 Mybatis 的源码过程中总结下来的,可能对读者不太友好,请结合我的源码注释(Mybatis源码分析 GitHub 地址.Mybatis-Spring 源码分析 GitHub ...

随机推荐

  1. 如何让每个 WordPress 页面有不同的风格或者样式

    如果使用 page.php 来处理所有页面的外观的话,答案肯定是不行的,但是如果使用不同的 WordPress 页面模板,就可以自定义每个页面的外观了. 比如你博客的所有的页面除了“关于”这个页面之外 ...

  2. BI开发之——Mdx基础语法(转至指尖流淌)

    Mdx为MultiDimensional  Expressions的缩写,多维表达式,是标准的OLAP查询语言.在多数OLAPServer都提供Mdx支持,如Microsoft Sql Server ...

  3. php if语句判定my查询是否为空

    <?php header("Content-type: text/html; charset=utf-8"); $username=$_GET['username']; $p ...

  4. 第二百六十二节,Tornado框架-cookie

    Tornado框架-cookie Cookie 是网站用来在客户端保存识别用户的一种小文件.一般来用库可以保存用户登 录信息.购物数据信息等一系列微小信息. self.set_cookie()方法,创 ...

  5. poj 1127:Jack Straws(判断两线段相交 + 并查集)

    Jack Straws Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 2911   Accepted: 1322 Descr ...

  6. VC++中CEdit控件实现回车换行

    1.通过回车Enter换行: 这里要有两个设置 <1>.将控件的属性设置为Mutilines->true; <2>.将控件的另一个属性设置为Want return-> ...

  7. C语言程序真正的启动函数

    为什么要用”真正”这个词?因为我们从学C语言开始,都会先明白这个道理,即C语言有且仅有一个main函数,main函数是C语言的入口点和出口点!(可以参考>http://www.dotcpp.co ...

  8. Android 5.0+删除Sdcard文件

    在Android5.0往后的平台上,你想通过单纯的调用File.delete()或着ContentResolver.delete()来删除Sdcard上的文件会删除失败.前者提示没有权限,后者仅仅删除 ...

  9. SVN备份及恢复

    一,SVN备份 svnadmin dump /data/svn/blzfmima/ > /tmp/full.svn.bak 其中/data/svn/blzfmima/为svn文件夹,导出成一个备 ...

  10. Linux中配置主机之间的免密ssh登陆

    假如 A 要登陆 B在A上操作:1.首先生成密钥对 ssh-keygen (提示时,直接回车即可) 2.再将A自己的公钥拷贝并追加到B的授权列表文件authorized_keys中 ssh-copy- ...