您的位置:首页 > 财经 > 金融 > 网络系统集成_广州宣传片制作公司_东莞seo网站排名优化公司_企业培训课程安排表

网络系统集成_广州宣传片制作公司_东莞seo网站排名优化公司_企业培训课程安排表

2025/1/10 10:30:33 来源:https://blog.csdn.net/caoli201314/article/details/144828100  浏览:    关键词:网络系统集成_广州宣传片制作公司_东莞seo网站排名优化公司_企业培训课程安排表
网络系统集成_广州宣传片制作公司_东莞seo网站排名优化公司_企业培训课程安排表

大家好,我是锋哥。今天分享关于【MyBatis如何处理延迟加载?】面试题。希望对大家有帮助;

MyBatis如何处理延迟加载?

1000道 互联网大厂Java工程师 精选面试题-Java资源分享网

在 MyBatis 中,延迟加载(Lazy Loading) 是指在访问某个对象的属性时,才去加载与该属性相关的关联数据,而不是在查询主对象时就加载所有相关的数据。这样可以提高性能,避免不必要的数据加载,尤其是在处理大型数据集时。

MyBatis 提供了两种延迟加载的方式:延迟加载属性延迟加载关联对象。下面详细介绍如何配置和使用这两种方式。

1. 延迟加载的基本原理

在 MyBatis 中,延迟加载通常涉及 一对一一对多 的关联关系。在默认情况下,MyBatis 会一次性加载所有相关联的数据。而启用延迟加载后,只有在访问关联数据时才会查询数据库。

2. 延迟加载配置

2.1 全局配置延迟加载

可以通过 MyBatis 的全局配置启用延迟加载功能。你需要在 mybatis-config.xml 配置文件中添加以下配置:

<configuration><settings><!-- 启用延迟加载 --><setting name="lazyLoadingEnabled" value="true"/><!-- 启用全局的延迟加载(即对所有关联属性进行延迟加载) --><setting name="aggressiveLazyLoading" value="false"/></settings>
</configuration>
  • lazyLoadingEnabled:启用延迟加载功能,默认值是 false,即不启用延迟加载。
  • aggressiveLazyLoading:决定是否在加载主对象时强制加载所有懒加载的属性。如果设置为 true,即使懒加载属性没有被访问,也会提前加载。
2.2 延迟加载关联属性

在映射文件中,你可以使用 fetchType 属性来控制延迟加载的行为。MyBatis 提供了两种加载方式:

  • EAGER(立即加载):即在查询主对象时,一并加载相关的属性。
  • LAZY(延迟加载):只有在访问相关属性时,才会触发数据库查询。

通常是在关联映射的 <association><collection> 标签上进行设置。

<resultMap id="userResultMap" type="User"><id property="id" column="id"/><result property="name" column="name"/><!-- 延迟加载关联对象 --><association property="profile" column="profile_id" javaType="Profile" fetchType="lazy"/>
</resultMap>

在这个例子中,profile 这个属性使用了延迟加载,只有在访问 user.getProfile() 时,才会从数据库加载 Profile 数据。

2.3 延迟加载集合属性

如果是集合类型的属性(如一对多关系),可以使用 <collection> 标签进行延迟加载配置。

<resultMap id="authorResultMap" type="Author"><id property="id" column="id"/><result property="name" column="name"/><!-- 延迟加载书籍集合 --><collection property="books" ofType="Book" column="author_id" fetchType="lazy"/>
</resultMap>

这里,booksAuthor 类的一个集合属性,它表示这个作者的所有书籍。只有在访问 author.getBooks() 时,才会从数据库加载书籍数据。

3. 延迟加载与会话管理

MyBatis 的延迟加载是基于 SqlSession 管理的,因此你需要确保在访问懒加载属性时,SqlSession 依然处于有效状态。通常情况下,延迟加载是在同一个 SqlSession 中进行的。如果 SqlSession 被关闭或提交后,再访问懒加载的属性时会抛出异常。

示例:
SqlSession session = sqlSessionFactory.openSession();
User user = session.selectOne("selectUserById", 1);
session.close();// 延迟加载将在这里触发
Profile profile = user.getProfile();

在这个例子中,getProfile() 方法会在懒加载时触发数据库查询,因此必须在 SqlSession 还没有关闭之前访问它。

4. 延迟加载的性能考量

虽然延迟加载可以减少不必要的数据加载,但是滥用延迟加载也可能导致性能问题,例如产生 N+1 查询问题,即如果你查询一个列表对象并逐个懒加载关联属性,那么会发送大量的 SQL 查询请求。

4.1 N+1 查询问题

当你查询一个包含懒加载关联属性的对象集合时,每次访问懒加载属性时都可能会执行一次查询,导致 SQL 查询次数增加。例如:

List<User> users = session.selectList("selectAllUsers");
for (User user : users) {// 每次访问 user.getProfile() 都会发起一个额外的查询Profile profile = user.getProfile();
}

解决这个问题的一个办法是使用 批量查询 或者通过 嵌套查询 来减少查询次数。

4.2 批量查询

MyBatis 提供了 @Many 注解(如果使用注解配置)来解决这一问题。例如,使用嵌套查询加载关联对象:

<resultMap id="userResultMap" type="User"><id property="id" column="id"/><result property="name" column="name"/><association property="profile" column="profile_id" javaType="Profile" select="selectProfileById"/>
</resultMap>

在这种情况下,selectProfileById 会在加载 User 对象时一起加载 Profile 数据,从而避免了多个查询。

5. 总结

MyBatis 的延迟加载机制允许开发者根据实际需要控制关联对象的加载时机,从而提升性能。通过配置全局设置或使用 fetchType="lazy" 配置,可以有效地延迟加载关联数据。然而,延迟加载也可能带来性能问题(如 N+1 查询问题),需要在实际应用中仔细权衡和优化。

  • 开启延迟加载:通过 lazyLoadingEnabled 和 fetchType="lazy" 进行配置。
  • 管理会话:确保在同一个 SqlSession 中访问懒加载属性。
  • 优化查询:避免 N+1 查询问题,可以使用嵌套查询或批量查询来减少查询次数。

使用延迟加载时,合理规划数据库查询,确保性能最优。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com