服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - Mybatis加载策略的实现方法

Mybatis加载策略的实现方法

2022-07-27 10:42JackierChan Java教程

Mybatis中一对一,一对多,多对多关系的配置及实现,可以实现对象的关联查询。实际开发过程中很多时候我们并不需要总是在加载用户信息时就一定要加载他的订单信息,这是就是我们常说的延时加载,本文给大家详细介绍实现方

MaBatis加载策略

1.什么是延迟加载

Mybatis中一对一,一对多,多对多关系的配置及实现,可以实现对象的关联查询。实际开发过程中很多时候我们并不需要总是在加载用户信息时就一定要加载他的订单信息。此时就是我们所说的延迟加载。

例如:

问题1:在一对多中,当我们有一个用户,它有个100个订单在查询用户的时候,要不要把关联的订单查出来?

  • 回答:在查询用户时,用户下的订单应该是,什么时候用,什么时候查询。(一对多)

**问题2:**在查询订单的时候,要不要把关联的用户查出来?

  • 在查询订单时,订单所属的用户信息应该是随着订单一起查询出来。(多对一) 1.1延迟加载

就是在需要用到数据时才进行加载,不需要用到数据时就不加载数据。延迟加载也称懒加载。

注意:

延迟加载是基于嵌套查询来实现的

  • 优点:

先从单表查询,需要时再从关联表去关联查询,大大提高数据库性能,因为查询单表要比关联查询多张表
速度要快。

  • 缺点:

因为只有当需要用到数据时,才会进行数据库查询,这样在大批量数据查询时,因为查询工作也要消耗时
间,所以可能造成用户等待时间变长,造成用户体验下降。

  • 在多表中:

一对多,多对多:通常情况下采用延迟加载
一对一(多对一):通常情况下采用立即加载

1.2实现

1.2.1 局部延迟加载

在association和collection标签中都有一个fetchType属性,通过修改它的值,可以修改局部的加载策略。

xml配置文件:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<!--
嵌套查询:查询用户所对应的订单
-->
    <resultMap id="getUserInfoWithNested" type="user">
        <id property="id" column="id"></id>
        <result property="username" column="username"></result>
        <result property="birthday" column="birthday"></result>
        <result property="sex" column="sex"></result>
        <result property="address" column="address"></result>
        <!--
        fetchType="lazy" 懒加载策略
        fetchType="eager" 立即加载策略
    -->
        <collection property="ordersList" ofType="com.lagou.domain.Orders" select="com.lagou.mapper.OrdersMapper.findUserAllOrder" column="id" fetchType="lazy" ></collection>
    </resultMap>
    <select id="findUserOrder2" resultMap="getUserInfoWithNested">
        select * from user
    </select>

1.2.2 设置触发延迟加载的方法

  • 大家在配置了延迟加载策略后,发现即使没有调用关联对象的任何方法,但是在你调用当前对象的equals、clone、hashCode、toString方法时也会触发关联对象的查询。
  • 我们可以在配置文件中使用lazyLoadTriggerMethods配置项覆盖掉上面四个方法。
?
1
2
3
4
5
<!--    设置延迟加载策略-->
    <settings>
        <!--        所有方法都会延迟加载-->
        <setting name="lazyLoadTriggerMethods" value="toString()"/>
    </settings>

1.2.3全局延迟加载

  • 引入全局延迟加载,目的是解放局部延迟加载在标签collection中加入一直家fetchType参数。从而可以做到所有的嵌套查询是实现全局延迟加载。
  • 在Mybatis的核心配置文件中可以使用setting标签修改全局的加载策略。
?
1
2
3
4
5
6
<settings>
<!--        所有方法都会延迟加载-->
        <setting name="lazyLoadTriggerMethods" value="toString()"/>
        <!--开启全局延迟加载功能-->
        <setting name="lazyLoadingEnabled" value="true"/>
    </settings>

注意:局部的加载策略优先级高于全局的加载策略。

订单没有被查询出来:

Mybatis加载策略的实现方法

到此这篇关于Mybatis加载策略的文章就介绍到这了,更多相关Mybatis加载策略内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/qq_41239465/article/details/123110158

延伸 · 阅读

精彩推荐
  • Java教程Spring-AOP 静态正则表达式方法如何匹配切面

    Spring-AOP 静态正则表达式方法如何匹配切面

    这篇文章主要介绍了Spring-AOP 静态正则表达式方法如何匹配切面的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不...

    小小工匠6032021-10-16
  • Java教程新手了解java 异常处理基础知识

    新手了解java 异常处理基础知识

    Java中异常提供了一种识别及响应错误情况的一致性机制,有效地异常处理能使程序更加健壮、易于调试。那么这篇文章总结了Java有效处理异常的三个原则...

    王星伟QAQ10042021-09-27
  • Java教程Java基础之多线程方法状态和创建方法

    Java基础之多线程方法状态和创建方法

    Java中可以通过Thread类和Runnable接口来创建多个线程,下面这篇文章主要给大家介绍了关于Java基础之多线程方法状态和创建方法的相关资料,需要的朋友可以参...

    无极的移动代码6252021-12-18
  • Java教程java计算π的多种方法

    java计算π的多种方法

    这篇文章主要介绍了使用java计算π的多种方法,代码详细,逻辑清晰,对于算法思路可能有所帮助,需要的朋友可以参考下...

    birdreamer5232021-09-09
  • Java教程Struts2实现CRUD(增 删 改 查)功能实例代码

    Struts2实现CRUD(增 删 改 查)功能实例代码

    CRUD是Create(创建)、Read(读取)、Update(更新)和Delete(删除)的缩写,它是普通应用程序的缩影。接下来通过本文给大家介绍Struts2实现CRUD(增 删 改 查...

    sky_zhangfan3352020-05-09
  • Java教程servlet之session简介_动力节点Java学院整理

    servlet之session简介_动力节点Java学院整理

    这篇文章主要介绍了servlet之session简介,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    fjdingsd4362020-12-07
  • Java教程mybatis 如何通过resultMap 返回long

    mybatis 如何通过resultMap 返回long

    这篇文章主要介绍了mybatis 如何通过resultMap 返回long的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...

    qq_160557656112021-10-19
  • Java教程Spring Boot系列教程之死信队列详解

    Spring Boot系列教程之死信队列详解

    这篇文章主要给大家介绍了关于Spring Boot系列教程之死信队列的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习...

    JackieZheng5712021-06-11