目录
前言
在高并发系统中,数据库查询是系统性能的瓶颈之一。为了提高查询效率,减少数据库的访问次数,缓存机制应运而生。MyBatis 作为一款优秀的 ORM 框架,内置了强大的查询缓存特性,支持一级缓存和二级缓存两级缓存机制。本文将详细介绍缓存的概念、MyBatis 的缓存机制以及如何配置和使用 MyBatis 缓存。
一、什么是缓存?
1. 什么是缓存?
缓存是存储在内存中的数据。
当用户查询数据时,系统可以直接从缓存中获取,而不需要访问数据库,从而提升查询效率。
2. 为什么使用缓存?
- 减少数据库交互,降低系统的开销。
- 提高查询效率,优化系统性能。
- 支持高并发,避免数据库成为系统瓶颈。
3. 什么样的数据适合使用缓存?
- 经常被查询
- 变化不频繁
对于频繁变更的数据(如订单状态),缓存并不适用,因为数据不一致的风险较高。
二、MyBatis 缓存机制
MyBatis 内置了强大的缓存机制,支持两级缓存:
- 一级缓存(本地缓存):默认开启,作用域为 SqlSession 级别
- 二级缓存(全局缓存):需要手动开启,作用域为 SqlSessionFactory 级别
1. 一级缓存(也叫本地缓存)
在使用一级缓存后,与数据库第一次会话(SqlSession )期间查询到的数据会被放入本地缓存当中。如果在同一个会话后续需要获取相同的数据,可以直接从缓存中获取,而没必要再去查询数据库
(1)一级缓存的特点
- 默认开启,不需要额外配置。
- 作用域是SqlSession 级别,即<