mybatis中一级缓存和二级缓存
1.一级缓存
一级缓存是SqlSession级别的缓存。在操作数据库时需要构造 sqlSession对象,在对象中有一个(内存区域)数据结构(HashMap)用于存储缓存数据。不同的sqlSession之间的缓存数据区域(HashMap)是互相不影响的。
Mybatis默认开启一级缓存。
一级缓存的作用域是同一个SqlSession,在同一个sqlSession中两次执行相同的sql语句,第一次执行完毕会将数据库中查询的数据写到缓存(内存),第二次会从缓存中获取数据将不再从数据库查询,从而提高查询效率。当一个sqlSession结束后该sqlSession中的一级缓存也就不存在了。
@Testpublic void testCache1() throws Exception{SqlSessionsqlSession = sqlSessionFactory.openSession();//创建代理对象UserMapperuserMapper = sqlSession.getMapper(UserMapper.class);//下边查询使用一个SqlSession//第一次发起请求,查询id为1的用户Useruser1 = userMapper.findUserById(1);System.out.println(user1);// 如果sqlSession去执行commit操作(执行插入、更新、删除),清空SqlSession中的一级缓存,这样做的目的为了让缓存中存储的是最新的信息,避免脏读。//更新user1的信息user1.setUsername("测试用户22");userMapper.updateUser(user1);//执行commit操作去清空缓存sqlSession.commit();//第二次发起请求,查询id为1的用户Useruser2 = userMapper.findUserById(1);System.out.println(user2);sqlSession.close();}
如果不commit的错误流程为:
开始执行时,开启事务,创建SqlSession对象
第一次调用mapper的方法findUserById(1)
更新数据
第二次调用mapper的方法findUserById(1),从一级缓存中取数据
aop控制 只要方法结束,sqlSession关闭 sqlsession关闭后就销毁数据结构,清空缓存
Service结束sqlsession关闭
因为上面有commmit操作,所以正确流程
开始执行时,开启事务,创建SqlSession对象
第一次调用mapper的方法findUserById(1)
更新数据
清空commit
第二次调用mapper的方法findUserById(1),从一级缓存中无数据,从数据库中取数据
aop控制 只要方法结束,sqlSession关闭 sqlsession关闭后就销毁数据结构,清空缓存
Service结束sqlsession关闭
只要是在同一个sqlssesion中,一级缓存才会生效,如果sqlssesion.commit()或者是sqlsession.close()就会清空sqlssion,一级缓存也随之消失。
2.二级缓存
二级缓存介绍
二级缓存是mapper级别的缓存,多个SqlSession去操作同一个Mapper的sql语句,多个SqlSession去操作数据库得到数据会存在二级缓存区域,多个SqlSession可以共用二级缓存,二级缓存是多个SqlSession共享的。
UserMapper有一个二级缓存区域(按namespace分,如果namespace相同则使用同一个相同的二级缓存区),其它mapper也有自己的二级缓存区域(按namespace分)。
也是就是说拥有相同的namespace的UserMapper共享一个二级缓存
开启缓存
SqlMapConfig.xml中
<setting name="cacheEnabled"value="true"/><!-- 全局配置参数,需要时再设置 --><settings><!-- 开启二级缓存 默认值为true --><setting name="cacheEnabled" value="true"/></settings>
在UserMapper.xml中开启二缓存,UserMapper.xml下的sql执行完成会存储到它的缓存区域(HashMap)。
下面是开启redis缓存:
<mapper namespace="cn.mybatis.xml.mapper.UserMapper"><!-- redis配置项 --><cache type="org.mybatis.caches.redis.RedisCache" /> ...
至于具体的redis与mybatis的整合请参见:https://blog.csdn.net/magi1201/article/details/85635878
如何使用二级缓存
public class Userimplements Serializable {//Serializable实现序列化,为了将来反序列化
// 二级缓存测试@Testpublic void testCache2() throws Exception {SqlSessionsqlSession1 = sqlSessionFactory.openSession();SqlSessionsqlSession2 = sqlSessionFactory.openSession();SqlSessionsqlSession3 = sqlSessionFactory.openSession();// 创建代理对象UserMapperuserMapper1 = sqlSession1.getMapper(UserMapper.class);// 第一次发起请求,查询id为1的用户Useruser1 = userMapper1.findUserById(1);System.out.println(user1);//这里执行关闭操作,将sqlsession中的数据写到二级缓存区域sqlSession1.close();//使用sqlSession3执行commit()操作UserMapperuserMapper3 = sqlSession3.getMapper(UserMapper.class);Useruser = userMapper3.findUserById(1);user.setUsername("张明明");userMapper3.updateUser(user);//执行提交,清空UserMapper下边的二级缓存sqlSession3.commit();sqlSession3.close();UserMapperuserMapper2 = sqlSession2.getMapper(UserMapper.class);// 第二次发起请求,查询id为1的用户Useruser2 = userMapper2.findUserById(1);System.out.println(user2);sqlSession2.close();}
执行流程:
sqlsession1中使用findUserById(1)
关闭sqlsession1
sqlsession3中使用findUserById(1),从缓存中取出数据
sqlSession3.commit();
sqlSession3.close()
sqlSession2中使用findUserById(1)无法拿到数据(commit刷新二级缓存)
sqlSession2.close()
参考文献:
https://blog.csdn.net/u012373815/article/details/47069223
https://blog.csdn.net/weixin_36380516/article/details/73194758
https://blog.csdn.net/eson_15/article/details/51669608
mybatis中一级缓存和二级缓存相关推荐
- MyBatis中的一级缓存和二级缓存介绍
先说缓存,合理使用缓存是优化中最常见的,将从数据库中查询出来的数据放入缓存中,下次使用时不必从数据库查询,而是直接从缓存中读取,避免频繁操作数据库,减轻数据库的压力,同时提高系统性能. 一级缓存 一级 ...
- java mysql 二级缓存_深入理解MyBatis中的一级缓存与二级缓存
http://blog.csdn.net/weixin_36380516/article/details/73194758 先说缓存,合理使用缓存是优化中最常见的,将从数据库中查询出来的数据放入缓存中 ...
- Mybatis 中的一级缓存与二级缓存
一,Mybatis中为什么要有缓存 缓存的意义是将用户经常查询的数据放入缓存(内存)中去,用户去查询数据的时候就不需要从磁盘(关系型数据库)中查询,直接从缓存中查询,从而提高了查询效率,解决了高并 ...
- MyBatis中一级缓存和二级缓存详解
缓存的作用 首先缓存的合理使用是优化中最常见的,将从数据库中查询出来的数据放入缓存中,下次使用时不必从数据库查询,而是直接从缓存中读取,避免频繁操作数据库,减轻数据的压力,同时提高系统性能. 为什么需 ...
- Mybatis一级缓存,二级缓存的实现就是这么简单
介绍 又到了一年面试季,所以打算写一点面试常问的东西,争取说的通俗易懂.面试高级岗,如果你说熟悉Mybatis,下面这些问题基本上都会问 Mybatis插件的实现原理? 如何写一个分页插件? Myba ...
- mybatis高级(3)_延迟加载_深度延迟_一级缓存_二级缓存
设置延迟加载需要在mybatis.xml中设置 注: 侵入式延迟加载为真时是延迟加载 侵入式延迟加载为假时是深度延迟加载 <!-- 延迟加载和深度延迟加载 --><settings& ...
- MyBatis框架:延迟加载策策略、一级缓存、二级缓存
MyBatis框架:延迟加载策略和缓存 Mybatis 延迟加载策略 1.1 何为延迟加载? 1.2 实现需求 1.3 使用association实现延迟加载 1.3.1 账户的持久层DAO接口 1. ...
- 浅谈Mybatis的一级缓存和二级缓存
MyBatis的缓存机制 缓存的引入 当我们大量执行重复的查询SQL语句的时候,会频繁的和数据库进行通信,会增加查询时间等影响用户体验的问题,可以通过缓存,以降低网络流量,使网站加载速度更快. MyB ...
- MyBatis】MyBatis一级缓存和二级缓存
转载自 MyBatis]MyBatis一级缓存和二级缓存 MyBatis自带的缓存有一级缓存和二级缓存 一级缓存 Mybatis的一级缓存是指Session缓存.一级缓存的作用域默认是一个SqlSe ...
最新文章
- dubbo总结——dubbo的使用场景
- 2021-1-17 随笔
- 串结构练习——字符串连接
- 概率论 第二章 随机变量及其分布
- SpringSecurity的简单使用使用案列说明
- C语言变长数组data[0]【总结】
- 形象的列举-C# 枚举
- 云原生架构及设计原则
- CTFbugku--菜鸟初学
- 在ps中画两个同心圆并且把两个同心圆进行任意角度切割
- iOS-----用LLDB调试,让移动开发更简单(二)
- 【雕刻机】使用雕刻机雕刻PCB
- 中国移动路由器怎么设置虚拟服务器,中国移动宽带无线wifi设置方法【图】
- iOS音频掌柜-- AVAudioSession
- wakeonlangui 下载_远程开机软件(Wake On Lan)下载 v2.11.18 官方中文版 - 比克尔下载
- 符文(灵晶)系统介绍
- Arduino基础篇(二)-- 常用的基本函数
- Excel 注解介绍.第一篇
- python期中考试试卷分析_最新期中考试试卷分析与反思
- 友盟小米收不到推送消息_友盟推送SDK集成测试、常见问题以及注意事项总结