MyBatis缓存

MyBatis缓存

起男 1,188 2020-09-16

Mybatis缓存

mybatis中有一级缓存和二级缓存,默认情况下一级缓存是开启的,而且是不能关闭的。

一级缓存是指SqlSession级别的缓存,当在同一个SqlSession中进行相同的sql语句查询时,第二次以后的查询不会从数据库查询,而是从缓存中获取,一级缓存最多缓存1024条sql。

二级缓存是指可以跨SqlSession的缓存。是mapper级别的缓存,对于mapper级别的缓存不同的SqlSession是可以共享的

一级缓存(SqlSession级别)

第一次发出一个查询sql,sql查询结果写入sqlsessionn的一级缓存中,缓存使用的数据结构是一个map

同一个sqlsession再次发出相同的sql,就从缓存中取出数据。如果两次中间出现commit操作(增删改),本sqlsession中的一级缓存区域全部清空,下次再去缓存中查询不到所以要从数据库查询,从数据库查询到再写入缓存

二级缓存(mapper级别)

二级缓存的范围是mapper级别(mapper同一个命名空间),mapper以命名空间为单位创建缓存数据结构,结构是map。mybatis的二级缓存是通过CacheExecutor实现的。CacheExecutor其实是Executor的代理对象。所有的查询操作,在CacheExecutor中都会先匹配缓存中的是否存在,不存在则查询数据库

使用配置

  • mybatis全局配置中启用二级缓存配置
  • 在对应的mapper.xml中配置cache标签
  • 在对应的select查询标签中添加useCache=true

缓存格式:

  • key:MapperID+offset+limit+sql+所有的入参
  • value:用户信息