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

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

缓存

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

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

mybatis一级缓存

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

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

@Test
    public 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架构

 


http://www.kler.cn/a/284818.html

相关文章:

  • Linux手动安装nginx
  • 7天用Go从零实现分布式缓存GeeCache(学习)(3)
  • 弹性盒子布局(Flexbox)详细介绍
  • mysql 更改 字段长度
  • 基于MATLAB+opencv人脸疲劳检测
  • Java-Redisson分布式锁+自定义注解+AOP的方式来实现后台防止重复请求扩展
  • .net开发日常笔记(持续更新)
  • 续:MySQL的并行复制
  • XtQuant是什么?哪家券商支持miniQMT,XtQuant?
  • 使用SQLite进行Python简单数据存储的线程安全解决方案
  • Centos服务器配置使用密钥登录
  • 【C++题解】1722 - 输出两位的巧数
  • Docker 部署 Kafka 可视化 Kafka-UI
  • Arco Voucher - 不知道有什么用的凭证单据录入表单插件
  • 简易STL实现 | Deque的实现
  • PyMOL的开源版和商业版如何选择 PyMOL开源版安装 PyMOL商业版安装 PyMOL安装教程 远程安装PyMOL正式版 官网版
  • PDF文本指令解析与文本水印去除
  • 【IDEA】一键重启多个服务
  • 游戏出海,燃动全球,“安全”如何通关?
  • 【C++】有关vector迭代器失效问题
  • 快速了解Git服务器端基础及基本操作命令(一)
  • mysql的group by怎么用
  • disk manager操作教程 如何使用Disk Manager组件 Mac如何打开ntfs格式文件
  • Open WebUI官方库:解锁人工智能服务的官方通道
  • git常见命令行及分支规范
  • MATLAB智能优化算法-学习笔记(1)——遗传算法求解0-1背包问题【过程+代码】