学堂 学堂 学堂公众号手机端

MyBatis中怎么进行延迟加载

lewis 3年前 (2022-12-25) 阅读数 2 #技术

在MyBatis中进行延迟加载可以通过配置来实现。延迟加载是指在需要使用某个属性时才去查询数据库加载该属性的值,而不是在查询主实体时就将所有相关属性都加载出来。

在MyBatis中可以通过使用和标签的fetchType属性来设置延迟加载方式。fetchType属性有两种取值,分别是lazy和eager。

  1. lazy加载:在需要使用某个关联属性时才去查询加载相关数据,可以减少不必要的数据查询,提高查询性能。可以通过在和标签中设置fetchType="lazy"来实现延迟加载。
<association property="author" column="author_id" javaType="Author" fetchType="lazy"/>
<collection property="comments" column="post_id" ofType="Comment" fetchType="lazy"/>
  1. eager加载:在查询主实体时就将所有关联属性加载出来,如果关联属性数据量较小且常用,可以使用eager加载方式。可以通过在和标签中设置fetchType="eager"来实现即时加载。
<association property="author" column="author_id" javaType="Author" fetchType="eager"/>
<collection property="comments" column="post_id" ofType="Comment" fetchType="eager"/>

需要注意的是,延迟加载需要在MyBatis的配置文件中开启延迟加载功能,可以通过设置lazyLoadingEnabled和aggressiveLazyLoading属性为true来开启。


<settings>
    <setting name="lazyLoadingEnabled" value="true"/>
    <setting name="aggressiveLazyLoading" value="true"/>
</settings>

通过在映射文件中配置fetchType属性和在配置文件中开启延迟加载功能,就可以实现在MyBatis中进行延迟加载。

版权声明

本文仅代表作者观点,不代表博信信息网立场。

热门