Mybatis 延迟加载

8.1 使用延迟加载意义

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

如果查询单表就可以满足需求,一开始先查询单表,当需要关联信息时,再关联查询,当需要关联信息再查询这个叫延迟加载。

mybatis中resultMap提供延迟加载功能,通过resultMap配置延迟加载。

8.2 配置mybatis支持延迟加载

设置项描述允许值默认值
lazyloadingEnabled全局性设置懒加载。如果设为‘false’,则所有相关联的都会被初始化加载。ture
false
false
aggressiveLazyLoading当设置为‘true’的时候,懒加载的对象可能被任何懒属性全部加载。否则,每个属性都按需加载。ture
false
true
<!-- 全局配置参数 -->
<settings>
    <!-- 延迟加载总开关 -->
    <setting name="lazyLoadingEnabled" value="true" />  
    <!-- 设置按需加载 -->
    <setting name="aggressiveLazyLoading" value="false" />
</settings>

8.3 延迟加载实现
8.3.1 实现思路

需求:
查询订单及用户的信息,一对一查询。

刚开始只查询订单信息

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

8.3.2 mapper.xml

 <select id="findOrderUserByLazyLoading" resultMap="LazyMap">
        select * from orders
 </select>

8.3.3 resultMap

    <resultMap type="com.brook.pojo.Order" id="LazyMap">
        <id property="id" column="id" />
        <result property="user_id" column="user_id" />
        <result property="number" column="number" />
        <result property="createtime" column="createtime" />
        <result property="note" column="note" />
        <association property="user" javaType="user" select="com.brook.mapper.UserMapper.findUserById" column="user_id">

        </association>
    </resultMap>

8.3.4 mapper.java

public List<Order> findOrderUserByLazyLoading() throws Exception;

8.3.5 测试代码

@Test
public void findOrderUserByLazyLoading() throws Exception
{
    SqlSession sqlSession = sqlSessionFactory.openSession();
    OrderMapper mapper = sqlSession.getMapper(OrderMapper.class);
    List<Order> orders=mapper.findOrderUserByLazyLoading();
    sqlSession.close();
    System.out.println(orders.get(0).getUser());
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值