由 Mybatis 源码畅谈软件设计(七):从根上理解 Mybatis 一级缓存

💡 原文中文,约7100字,阅读约需17分钟。
📝

内容提要

本文介绍了MyBatis中一级缓存的实现原理,包括生效范围和失效条件。一级缓存基于SqlSession,不同SqlSession之间不共享,主要用于减少重复查询以提高性能。执行插入、删除和更新操作会导致缓存失效,缓存存放的是对象引用,修改后会影响后续查询结果。

🎯

关键要点

  • 本文介绍了MyBatis中一级缓存的实现原理,包括生效范围和失效条件。

  • 一级缓存基于SqlSession,不同SqlSession之间不共享,主要用于减少重复查询以提高性能。

  • 执行插入、删除和更新操作会导致缓存失效,缓存存放的是对象引用,修改后会影响后续查询结果。

  • 一级缓存的生效范围是SqlSession级别,默认情况下是启用的。

  • 一级缓存的实现依赖于PerpetualCache,使用HashMap存储数据。

  • 一级缓存失效的场景包括执行Insert、Delete、Update语句和调用sqlSession#clearCache方法。

  • 在同一个SqlSession中,如果对缓存中返回的对象进行了修改,后续查询将返回修改后的数据,可能导致脏读。

延伸问答

MyBatis中的一级缓存是什么?

MyBatis中的一级缓存是基于SqlSession的缓存机制,用于减少重复查询,提高性能。

一级缓存的生效范围是什么?

一级缓存的生效范围是SqlSession级别,不同的SqlSession之间不共享缓存。

哪些操作会导致一级缓存失效?

执行插入、删除和更新操作会导致一级缓存失效,此外调用sqlSession#clearCache方法也会清空缓存。

一级缓存是如何存储数据的?

一级缓存使用PerpetualCache实现,数据存储在HashMap中,缓存的是对象的引用。

在同一个SqlSession中修改缓存对象会有什么影响?

在同一个SqlSession中修改缓存对象后,后续查询将返回修改后的数据,可能导致脏读。

如何清空MyBatis的一级缓存?

可以通过执行带有flushCache=true的SQL语句或调用sqlSession#clearCache方法来清空一级缓存。

🏷️

标签

➡️

继续阅读