Mybatis缓存

Mybatis 中有一级缓存和二级缓存


默认情况下一级缓存是开启的,而且是不能关闭的。一级缓存 是指 SqlSession 级别的缓存,当在同一个 SqlSession 中进行相同的 SQL 语句查询时,第二次以 后的查询不会从数据库查询,而是直接从缓存中获取,一级缓存最多缓存 1024 条 SQL。
二级缓存 是指可以跨 SqlSession 的缓存。是 mapper 级别的缓存,对于 mapper 级别的缓存不同的 sqlsession 是可以共享的。

一级缓存原理(sqlsession 级别)


第一次发出一个查询 sql,sql 查询结果写入 sqlsession 的一级缓存中,缓存使用的数据结构是一 个 map。
key:MapperID+offset+limit+Sql+所有的入参
value:用户信息
同一个 sqlsession 再次发出相同的 sql,就从缓存中取出数据。如果两次中间出现 commit 操作 (修改、添加、删除),本 sqlsession 中的一级缓存区域全部清空,下次再去缓存中查询不到所 以要从数据库查询,从数据库查询到再写入缓存。

二级缓存原理(mapper 基本)


二级缓存的范围是 mapper 级别(mapper 同一个命名空间),mapper 以命名空间为单位创建缓
存数据结构,结构是 map。mybatis 的二级缓存是通过 CacheExecutor 实现的。CacheExecutor
     13/04/2018 Page 138 of 283
其实是 Executor 的代理对象。所有的查询操作,在 CacheExecutor 中都会先匹配缓存中是否存 在,不存在则查询数据库。
key:MapperID+offset+limit+Sql+所有的入参
具体使用需要配置:

1:Mybatis 全局配置中启用二级缓存配置
# application.properties 中

# 开启mybatis的二级缓存
mybatis.configuration.cache-enabled=true

2:在对应的 Mapper.xml 中配置 cache 节点 
配置方式:
 

<cache eviction="LRU" flushInterval="100000" readOnly="true" size="1024">


# memoryStoreEvictionPolicy
# LRU:(Least Rencently Used)新来的对象替换掉使用时间算最近很少使用的对象。
# LFU:(Least Frequently Used)替换掉按命中率高低算比较低的对象。
# FIFO: (First In First Out)把最早进入二级缓存的对象替换掉。
3:在对应的 select 查询节点中添加 useCache=true

# 开启mybatis的二级缓存
 

<select id="findById" parameterType="java.lang.Long" useCache=true >
    select * from user
    where id = #{id,jdbcType=BIGINT}
</select>

   

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值