面试官:MyBatis二级缓存如何工作?关联数据刷新机制是怎样的?我有点迷茫。

2026-05-22 10:311阅读0评论SEO问题
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计2167个文字,预计阅读时间需要9分钟。

面试官:MyBatis二级缓存如何工作?关联数据刷新机制是怎样的?我有点迷茫。

MyBatis 缓存介绍:MyBatis 提供了对缓存的支撑,但在默认情况下,只有一级缓存被开启,二级缓存需要手动开启。一级缓存仅针对单个查询结果有效。

来源:blog.csdn.net/qq_38245668/article/details/105803298

1、MyBatis缓存介绍

Mybatis提供对缓存的支持,但是在没有配置的默认情况下,它只开启一级缓存,二级缓存需要手动开启。

一级缓存只是相对于同一个SqlSession而言。 也就是针对于同一事务,多次执行同一Mapper的相同查询方法,第一查询后,MyBatis会将查询结果放入缓存,在中间不涉及相应Mapper的数据更新(Insert,Update和Delete)操作的情况下,后续的查询将会从缓存中获取,而不会查询数据库。

二级缓存是针对于应用级别的缓存,也就是针对不同的SqlSession做到缓存。 当开启二级缓存时,MyBatis会将首次查询结果存入对于Mapper的全局缓存,如果中间不执行该Mapper的数据更新操作,那么后续的相同查询都将会从缓存中获取。

2、二级缓存问题

根据二级缓存的介绍发现,如果Mapper只是单表查询,并不会出现问题,但是如果Mapper涉及的查询出现 联表 查询,如 UserMapper 在查询 user 信息时需要关联查询 组织信息,也就是需要 user 表和 organization 表关联,OrganizationMapper 在执行更新时并不会更新 UserMapper 的缓存,结果会导致在使用相同条件 使用 UserMapper 查询 user 信息时,会等到未更新前的 organization 信息,造成数据不一致的情况。

阅读全文

本文共计2167个文字,预计阅读时间需要9分钟。

面试官:MyBatis二级缓存如何工作?关联数据刷新机制是怎样的?我有点迷茫。

MyBatis 缓存介绍:MyBatis 提供了对缓存的支撑,但在默认情况下,只有一级缓存被开启,二级缓存需要手动开启。一级缓存仅针对单个查询结果有效。

来源:blog.csdn.net/qq_38245668/article/details/105803298

1、MyBatis缓存介绍

Mybatis提供对缓存的支持,但是在没有配置的默认情况下,它只开启一级缓存,二级缓存需要手动开启。

一级缓存只是相对于同一个SqlSession而言。 也就是针对于同一事务,多次执行同一Mapper的相同查询方法,第一查询后,MyBatis会将查询结果放入缓存,在中间不涉及相应Mapper的数据更新(Insert,Update和Delete)操作的情况下,后续的查询将会从缓存中获取,而不会查询数据库。

二级缓存是针对于应用级别的缓存,也就是针对不同的SqlSession做到缓存。 当开启二级缓存时,MyBatis会将首次查询结果存入对于Mapper的全局缓存,如果中间不执行该Mapper的数据更新操作,那么后续的相同查询都将会从缓存中获取。

2、二级缓存问题

根据二级缓存的介绍发现,如果Mapper只是单表查询,并不会出现问题,但是如果Mapper涉及的查询出现 联表 查询,如 UserMapper 在查询 user 信息时需要关联查询 组织信息,也就是需要 user 表和 organization 表关联,OrganizationMapper 在执行更新时并不会更新 UserMapper 的缓存,结果会导致在使用相同条件 使用 UserMapper 查询 user 信息时,会等到未更新前的 organization 信息,造成数据不一致的情况。

阅读全文