当前位置: 首页 > news >正文

MyBatis一级缓存和二级缓存以及 mybatis架构

缓存

数据缓存,让数据离我们执行的程序更近一点,让程序能够快速的获取到数据

缓存的作用就是减轻数据库的压力,提高查询性能。缓存实现的原理是从数据库中查询出来的对象在使用完后不要销毁,而是存储在内内(缓存)中,当再次需要获取该对象时,直接从缓存中直接获取,不再向数据库只是select语句,从而减少数据库的查询压力

mybatis一级缓存

一级缓存默认是SqlSession级别的,在每一个SqlSession中查询到的数据先缓存在SqlSession对象中,第二次查询时,先从缓存中查询,如果有直接返回,没有则查询数据库

必须是同一个SqlSession查询,SqlSession没有关闭的状态下

@Testpublic void test5() {//一级缓存测试SqlSession sqlSession = MybatisUtil.getSqlSession();TeacherDao teacherDao = sqlSession.getMapper(TeacherDao.class);Teacher teacher1=teacherDao.findTeacherById(4);System.out.println(teacher1);Teacher teacher2=teacherDao.findTeacherById(4);System.out.println(teacher2);sqlSession.commit();sqlSession.close();}

一级缓存流程

一级缓存生命周期:

开始于 SqlSession的创建

如果期间执行了新增、修改、删除也会清空SqlSession对象中的缓存数据,防止脏读数据

调用sqlSession.clearCache()强制清空缓存数据

结束于SqlSession的关闭,

二级缓存

二级缓存是SqlsessionFactory级别,可以让多个SqlSession共享数据  mybatis默认没有开启二级缓存,使用时需要在mybatis配置文件中配置开启,二级缓存是 SqlSessionFactory 级别的,根据 mapper 的 namespace 划分 区域的,相同 namespace 的 mapper 查询的数据缓存在同一个区域,如果使 用 mapper 代理方法每个 mapper 的 namespace 都不同,此时可以理解为二 级缓存区域是根据 mapper 划分。

如果开启了二级缓存,当SqlSession关闭时,会将一级缓存中的数据存储到二级缓存中(也就是SqlsessionFactory中), 当其他的SqlSession就可以二级缓存中查询到之前SqlSession查询的数据。

每次查询会先从缓存区域查找,如果找不到则从数据库查询,并将查询到数 据写入缓存。Mybatis 内部存储缓存使用一个 HashMap,key 为 hashCode+sqlId+Sql 语句。value 为从查询出来映射生成的 java 对象

开启二级缓存三个配置

1、在mybatis.xml配置 <setting name="cacheEnabled" value="true"/> false则关闭二级缓存。

 2、对象序列化,将所有的 POJO 类实现序列化接口 Java.io. Serializable。

 3、配置映射文件,在 Mapper 映射文件中添加<cache />,表示此 mapper 开启二级缓存 * select标签useCache="true"使用二级缓存,false关闭二级缓存。

 

如果期间执行了新增、修改、删除也会清空SqlSession对象中的缓存数据,防止脏读数据

 mybatis架构

 

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 五指生望京新店开业,开启健康之旅
  • 用AppleScript做macOS UI自动化
  • 外卖系统开发:如何打造一个无缝衔接的用户体验?
  • 建模模型时间说明
  • GPT应用篇:如何用GPT4.0写一本言情小说?
  • atsec出席2024 PCI社区会议
  • 什么软件可以约束员工摸鱼行为?黑神话悟空爆火!上班玩游戏,职场新利器来啦
  • 目标 CDC实例数据库更改密码,预定启动报错SQL 错误代码为“-30082”。SQL 状态为:08001。
  • Haporxy搭建web集群
  • docker 数据存储
  • 财经群里看猴?!苏轼:转念的力量——早读(逆天打工人爬取热门微信文章解读)
  • 别让语法拖后腿:ChatGPT助你告别改稿噩梦!【建议收藏】
  • FPGA 如何进入 AI 领域的思考
  • 【xilinx】学习ZynqSOC发现教程和vitis2023版本界面对不上
  • 《JavaEE进阶》----1.<JavaEE进阶可以学到什么>
  • php的引用
  • create-react-app做的留言板
  • gitlab-ci配置详解(一)
  • JavaScript DOM 10 - 滚动
  • JSONP原理
  • MyEclipse 8.0 GA 搭建 Struts2 + Spring2 + Hibernate3 (测试)
  • Mysql优化
  • PAT A1050
  • Selenium实战教程系列(二)---元素定位
  • Spring-boot 启动时碰到的错误
  • Sublime Text 2/3 绑定Eclipse快捷键
  • TiDB 源码阅读系列文章(十)Chunk 和执行框架简介
  • Vue官网教程学习过程中值得记录的一些事情
  • 从零到一:用Phaser.js写意地开发小游戏(Chapter 3 - 加载游戏资源)
  • 动态魔术使用DBMS_SQL
  • 个人博客开发系列:评论功能之GitHub账号OAuth授权
  • 关于Android中设置闹钟的相对比较完善的解决方案
  • 关于Java中分层中遇到的一些问题
  • 如何打造100亿SDK累计覆盖量的大数据系统
  • 如何用Ubuntu和Xen来设置Kubernetes?
  • ​flutter 代码混淆
  • ​LeetCode解法汇总2808. 使循环数组所有元素相等的最少秒数
  • !!Dom4j 学习笔记
  • # 透过事物看本质的能力怎么培养?
  • (03)光刻——半导体电路的绘制
  • (2)MFC+openGL单文档框架glFrame
  • (2024,RWKV-5/6,RNN,矩阵值注意力状态,数据依赖线性插值,LoRA,多语言分词器)Eagle 和 Finch
  • (4.10~4.16)
  • (Redis使用系列) Springboot 使用redis实现接口Api限流 十
  • (ZT)一个美国文科博士的YardLife
  • (二)Kafka离线安装 - Zookeeper下载及安装
  • (附源码)c#+winform实现远程开机(广域网可用)
  • (附源码)计算机毕业设计SSM在线影视购票系统
  • (含笔试题)深度解析数据在内存中的存储
  • (黑马出品_高级篇_01)SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式
  • (三)uboot源码分析
  • (一)Spring Cloud 直击微服务作用、架构应用、hystrix降级
  • (转)Java socket中关闭IO流后,发生什么事?(以关闭输出流为例) .
  • (转)Sql Server 保留几位小数的两种做法
  • (状压dp)uva 10817 Headmaster's Headache