## MyBatis缓存
Mybatis 中有**一级缓存**和**二级缓存**。
一级缓存是指 **SqlSession** 级别的缓存,当在同一个 SqlSession 中进行相同的 SQL 语句查询时,第二次以后的查询不会从数据库查询,而是直接从缓存中获取,一级缓存最多缓存 1024 条 SQL。
二级缓存是指可以**跨 SqlSession** 的缓存。 是 **mapper** 级别的缓存,对于 mapper 级别的缓存不同的sqlsession 是可以共享的。
MyBatis缓存示意图:

### 一级缓存(SqlSession级别)
第一次发出一个查询 sql, sql 查询结果写入 sqlsession 的一级缓存中,缓存使用的数据结构是一个 **map**。
key: MapperID+offset+limit+Sql+所有的入参
value:查询结果
同一个 sqlsession 再次发出相同的 sql,就从缓存中取出数据。如果两次中间出现 commit 操作(修改、添加、删除),本 sqlsession 中的一级缓存区域全部清空。
配置一级缓存:
```xml
<setting name="localCacheScope" value="SESSION"/>
```
在MyBatis的配置文件中,添加上述语句,就可以使用一级缓存。共有两个选项,`SESSION`或者`STATEMENT`,默认是`SESSION`级别,即在一个MyBatis会话中执行的所有语句,都会共享这一个缓存。一种是`STATEMENT`级别,可以理解为缓存只对当前执行的这一个`Statement`有效。
### 二级缓存(Mapper级别)
二级缓存的范围是 **mapper** 级别(mapper 同一个命名空间), mapper 以命名空间为单位创建缓存数据结构,结构是 map。 mybatis 的二级缓存是通过 CacheExecutor 实现的。 CacheExecutor其实是 Executor 的代理对象。所有的查询操作,在 CacheExecutor 中都会先匹配缓存中是否存在,不存在则查询数据库。
key: MapperID+offset+limit+Sql+所有的入参
具体使用需要配置:
1. Mybatis 全局配置中启用二级缓存配置
2. 在对应的 Mapper.xml 中配置 cache 节点
3. 在对应的 select 查询节点中添加 useCache=true
二级缓存除了使用内置的缓存实现,也可以自己通过实现`Cache`接口来实现。
配置二级缓存:
```xml
<setting name="cacheEnabled" value="true"/>
```
在MyBatis的配置文件中,添加上述语句,然后在对应的Mapper文件中添加`<cache>`或`<cache-ref>`标签即可开启二级缓存。

MyBatis缓存