目录
1. 缓存机制介绍
MyBatis 的缓存机制是为了提高应用程序的性能而设计的,通过缓存策略来减少数据库的查询次数。MyBatis 提供了两种类型的缓存:一级缓存和二级缓存。
- 默认情况下,只有一级缓存(session级别的缓存,也称为本地缓存)开启。
- 默认情况下,二级缓存是关闭的,需要显式启用。
- 为了提高扩展性。MyBatis定义了缓存接口Cache。我们可以通过实现Cache接口来自定义二级缓存
一级缓存和二级缓存图示
2. 一级缓存
一级缓存是默认启用的,它是基于 SqlSession 的缓存。这意味着在同一个 SqlSession 的生命周期内,对于相同的 SQL 查询,MyBatis 会先检查缓存中是否有之前执行该查询的结果,如果有,则直接从缓存中获取,而不是再次执行 SQL 查询。
- 作用范围:一级缓存的作用范围仅限于同一个 SqlSession。
- 自动管理:一级缓存由 MyBatis 自动管理,无需任何配置。
- 失效条件:
- 当执行更新操作(包括 insert、update 或 delete)时,一级缓存会被清空。
- 当 SqlSession 关闭或执行了 clearCache() 方法时,一级缓存也会被清空。
- 如果 SqlSession 设置了 autoCommit 为 true 并且执行了 commit,那么缓存也会被清空。
- 将一级缓存的作用域设置为语句级别(
localCacheScope
设置为STATEMEN