MyBatis学习(五)缓存机制

概述

  1. MyBatis 包含一个非常强大的查询缓存特性,它可以非常方便地配置和定制。缓存可以极大的提升查询效率
  2. MyBatis系统中默认定义了两级缓存
  3. 一级缓存和二级缓存。
  • 默认情况下,只有一级缓存(SqlSession级别的缓存,也称为本地缓存)开启。
  • 二级缓存需要手动开启和配置,他是基于namespace级别的缓存。
  • 为了提高扩展性。MyBatis定义了缓存接口Cache。我们可以通过实现Cache接口来自定义二级缓存

一级缓存(本地缓存)

概念

  1. 与数据库同一次会话期间查询到的数据会放在本地缓存中,以后如果需要获取相同的数据,直接从缓存中拿,没必要再去查数据库
  2. 一级缓存默认开启,无法关闭

一级缓存失效情况

  1. sqlSession不同
  2. sqlSession相同,查询条件不同(当前一级缓存中还没有这个数据)
  3. sqlSession相同,但在两次查询之间执行了增删改操作(这次的增删改操作可能对当前数据有影响)
  4. sqlSession相同,清除缓存(sqlSession.clearCache)

二级缓存(全局缓存)

概念

  1. 基于namespace级别的缓存,一个namespace对应一个二级缓存

工作机制

  1. 一个会话如果关闭,一级缓存中的数据会被保存到二级缓存中,新的会话查询信息就可以参照二级缓存中的内容
  2. 只有一级缓存的会话关闭才会保存到二级缓存中

使用配置

  1. 在全局配置文件中开启二级缓存
<!--开启二级缓存-->
        <setting name="cacheEnabled" value="true"/>
  1. 在mapper.xml中配置使用二级缓存
<cache></cache>

在这里插入图片描述

  1. POJO要实现序列化接口

相关的设置参数

  1. 在select标签中有一个参数useCache,默认为true,若为false,则该查询不使用二级缓存,否则使用。
  2. 增删改标签有参数flushCache参数,默认为true,执行完该操纵就清除缓存(一级、二级);查询标签中的flushCache参数默认值为false
  3. sqlSession.clearCache()只是清除一级缓存

使用第三方缓存

ehcache

下载地址:
https://github.com/mybatis/ehcache-cache/releases
下载的是依赖包而不是源码
在这里插入图片描述
三个jar包:
在这里插入图片描述
lib目录下两个
在这里插入图片描述
还有一个xml配置文件,放到根目录下
下载地址:
https://wwa.lanzoui.com/iItPopf3jhe

总结

在这里插入图片描述

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值