Mybatis一级缓存和二级缓存

1.一级缓存(默认开启)

Mybatis对缓存提供支持,但是在没有配置的默认情况下,它只开启一级缓存。

​ 一级缓存只是相对于同一个SqlSession而言。所以在参数和SQL完全一样的情况下,我们使用同一个SqlSession对象调用一个Mapper方法,只执行一次SQL,使用SelSession第一次查询后,MyBatis会将其放在缓存中,以后再查询的时候,如果之前没有执行commit操作,并且缓存没有超时的情况下,SqlSession都会取出当前缓存的数据,而不会再次发送SQL到数据库。每次sqlSession去执行commit操作(插入,更新,删除)会自动清除sqlSession中的一级缓存,session关闭后,该sqlSession中一级缓存中的内容将自动清除,避免脏读。

不同的sqlSession之间的缓存区域(HashMap)互不影响。

2.二级缓存(手动开启)

mybaits的二级缓存是mapper范围级别,除了在SqlMapConfig.xml设置二级缓存的总开关,还要在具体的mapper.xml中开启二级缓存。

<setting name="cacheEnabled" value="true" />开启全局配置

在mapper.xml配置文件开启缓存:<cache/>

pojo需要实现序列化接口。

sqlSession需要关闭后才能将数据写到二级缓存中,否则二级缓存中无相应数据。

任何一个sqlsession执行提交操作都会清空二级缓存中的内容。

在statement中设置useCache=false可以禁用当前select语句的二级缓存,即每次查询都会发出sql去查询

使用场景:

  • 用于查询非常消耗时间的查询请求
  • 用于访问次数多的查询请求且用户对查询结果实时性要求不高
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值