MyBatis 提供了两级缓存机制,旨在减少数据库访问次数,提升数据访问性能。 一级缓存是 SqlSession 级别的,而二级缓存是 SqlSessionFactory 级别的。 本文将深入探讨 MyBatis 一级缓存和二级缓存的原理、配置、使用场景以及区别,帮助你更好地理解和运用这两种缓存机制,打造高性能的 MyBatis 应用。
1. MyBatis 缓存体系概览
MyBatis 的缓存体系分为两级:
- 一级缓存 (Local Cache): 也称为 SqlSession 缓存,是 MyBatis 内置的、默认开启的缓存。 它的作用范围是 SqlSession,即一个数据库会话。
- 二级缓存 (Second Level Cache): 也称为全局缓存,需要手动开启和配置。 它的作用范围是 Mapper 接口的命名空间,可以被多个 SqlSession 共享。
2. 一级缓存 (SqlSession 缓存)
2.1 一级缓存的原理
MyBatis 在一个 SqlSession 内部维护一个简单的缓存,用于存储查询结果。 当 SqlSession 执行相同的查询时,MyBatis 会首先从一级缓存中查找结果,如果找到则直接返回,避免了重复查询数据库。
一级缓存的生命周期:
一级缓存的生命周期与 SqlSession 相同。 当 SqlSession 创建时,一级缓存也随之创建; 当 SqlSession 关闭时,一级缓存也会被清除。
一级缓存的存储结构:
MyBatis 使用一个 HashMap 来存储一级缓存的数据。 Key 是由 SQL 语句、参数和 RowBounds 对象组成的,Value 是查询结果。
2.2 一级缓存的特点
- 默认开启: 一级缓存是 MyBatis 默认开启的,无需手动配置。
- SqlSession 级别: 一级缓存的作用范围是 SqlSession,不同 SqlSession 之间无法共享缓存数据。
- 自动管理: MyBatis 会自动管理一级缓存的生命周期和数据同步。
- 简单高效: 一级缓存的实现简单高效,对性能影响较小。
2.3 一级缓存的失效情况
以下情况会导致一级缓存失效:
- 执行了 UPDATE、INSERT 或 DELETE 操作: