MyBatis的cache缓存

本文详细介绍了MyBatis的一级和二级缓存。一级缓存是SqlSession级别的,通过SqlSession对象中的Executor对象存储,执行更新操作时会被清除。二级缓存是Application级别,配置开启后可跨SqlSession共享数据,提升查询效率。二级缓存的配置和使用需注意其适用场景和可能引发的问题,如数据一致性问题。此外,还提到了Redis等第三方缓存的使用和MyBatis与Hibernate的区别。
摘要由CSDN通过智能技术生成


什么是缓存:

缓存是计算机中的一块存储区域,把数据放入到存储区域中,读取速度快


一、MyBatis的缓存

  1. MyBatis 包含一个非常强大的查询缓存特性,它可以非常方便地配置和定制。
  2. 默认情况下是没有开启缓存的,除了局部的 session 缓存,可以增强变现而且处理循环 依赖也是必须的。要开启二级缓存,你需要在你的 SQL 映射文件中添加一行: <cache/>

1、什么是一级缓存? 为什么使用一级缓存?

  1. 每当我们使用MyBatis开启一次和数据库的会话,MyBatis会创建出一个SqlSession对象表示一次数据库会话。

  2. 在对数据库的一次会话中,我们有可能会反复地执行完全相同的查询语句,如果不采取一些措施的话,每一次查询都会查询一次数据库,而我们在极短的时间内做了完全相同的查询,那么它们的结果极有可能完全相同,由于查询一次数据库的代价很大,这有可能造成很大的资源浪费。
  3. 为了解决这一问题,减少资源的浪费,MyBatis会在表示会话的SqlSession对象中建立一个简单的缓存,将每次查询到的结果缓存起来, 当下次查询的时候,如果判断先前有个完全一样的查询,会直接从缓存中将结果取出,返回给用户,不需要再进行一次数据库查询了。
  4. 如下图所示,MyBatis会在一次会话的表示----一个SqlSession对象中创建一个本地缓存(local cache),对于每一次查询,都会尝试根据查询的条件去本地缓存中查找是否存在,如果在缓存中,就直接从缓存中取出,然后返回给用户;否则,从数据库读取数据,将查询结果存入缓存并返回给用户。(对于会话(Session)级别的数据缓存,我们称之为一级数据缓存,简称一级缓存

1)一级缓存

2)MyBatis中的一级缓存组织

SqlSession对象、Executor对象、Cache对象之间的关系如下图所示:

 PepetualCache的代码实现:

 PerpetualCache实现原理其实很简单,其内部就是通过一个简单的HashMap<k,v>来实现的,没有其他的任何限制。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值