在月黑风高的某天夜晚,boss chen语重心长的发条了消息给小草说:“小草啊,是时候写写博客来记录平常自己积累的东西了......”。小草一听,平常没有写博客的习惯,在平常开发中只是用笔记记录自己的所得(分散的小点),写博客的心思还处于萌芽之中,boss chen的话彻底让萌芽“破土而出”。

之后便有了本博主的博客之旅......小草的Dream。

  第一次写博客,也不知道从哪里开始写,想来想去先从平常接触比较多的mybatis开始写吧!

mybatis的缓存机制

一级缓存

mybatis配置中是默认启用一级缓存的(默认的是SESSION级别),当然也可以再次手动设置

<setting name="localCacheScope" value="SESSION"/>

注:一级缓存有连个选项,SESSION或者STATEMENT,默认是SESSION。

测试案例:

1.在一个service中对某个id查询多次

可以看出真正与数据库交互的只有第一次查询,第二次,第三次查询是通过查询缓存得出的。

2.当在同一个会话中进行了增删语句之后,一级缓存会失效

例如当在上述例子中的第二部修改为删除的一条语句,一级缓存会失效

可以看出在第二部进行删除操作后,1~3步骤都对数据库进行操作,所以在进行增删的操作后,执行相同的查询语句,一级缓存会失效。

3.原理见图(欢迎指正)

4.SqlSession 方法解析:

SqlSession中提供了与数据交互的方法

  <T> T selectOne(String var1);

  <T> T selectOne(String var1, Object var2);

  <E> List<E> selectList(String var1);

  <E> List<E> selectList(String var1, Object var2);

  <E> List<E> selectList(String var1, Object var2, RowBounds var3);

  <K, V> Map<K, V> selectMap(String var1, String var2);

  <K, V> Map<K, V> selectMap(String var1, Object var2, String var3);

  <K, V> Map<K, V> selectMap(String var1, Object var2, String var3, RowBounds var4);

  <T> Cursor<T> selectCursor(String var1);

  <T> Cursor<T> selectCursor(String var1, Object var2);

  <T> Cursor<T> selectCursor(String var1, Object var2, RowBounds var3);

  void select(String var1, Object var2, ResultHandler var3);

  void select(String var1, ResultHandler var2);

  void select(String var1, Object var2, RowBounds var3, ResultHandler var4);

  int insert(String var1);

  int insert(String var1, Object var2);

  int update(String var1);

  int update(String var1, Object var2);

  int delete(String var1);

  int delete(String var1, Object var2);

  void commit();

  void commit(boolean var1);

  void rollback();

  void rollback(boolean var1);

  List<BatchResult> flushStatements();

  void close();

  void clearCache();

  Configuration getConfiguration();

  <T> T getMapper(Class<T> var1);

  Connection getConnection();

Executor是与操作数据库有关的职责都会被委托。Executor有若干个实现类,为Executor赋予了不同的能力,之后参考源码进行深入学习。

5.至此,通过源码的分析一个简单的上述案例的原因(insert/delete/update方法,缓存就会刷新的原因)

SqlSession的insert方法和delete方法,都会统一走update的流程,代码如下所示:

  @Override

  public int insert(String statement, Object parameter) { return update(statement, parameter);
  }

   @Override
  public int delete(String statement) { return update(statement, null);
  }

  update方法也是委托给了Executor执行。BaseExecutor的执行方法如下所示。

  @Override

  public int update(MappedStatement ms, Object parameter) throws SQLException {
    ErrorContext.instance().resource(ms.getResource()).activity("executing an update").object(ms.getId());

     if (closed) {

       throw new ExecutorException("Executor was closed.");
    }
      clearLocalCache();

        return doUpdate(ms, parameter);
  }

  每次执行update前都会清空localCache。

mybatis一级缓存:

MyBatis一级缓存的生命周期和SqlSession一致。

MyBatis一级缓存内部设计简单,只是一个没有容量限定的HashMap,在缓存的功能性上有所欠缺。

MyBatis的一级缓存最大范围是SqlSession内部,有多个SqlSession或者分布式的环境下,数据库写操作会引起脏数据,建议设定缓存级别为Statement。

(未完待续......)

之后一遍介绍mybatis的二级缓存,请期待......

mybati缓存机制之一级缓存的更多相关文章

  1. MyBatis缓存机制(一级缓存,二级缓存)

    一,MyBatis一级缓存(本地缓存) My Batis 一级缓存存在于 SqlSession 的生命周期中,是SqlSession级别的缓存.在操作数据库时需要构造SqlSession对象,在对象中 ...

  2. hibernate笔记--缓存机制之 一级缓存(session缓存)

    一级缓存: 又称为session缓存,它和session生命周期相同,周期非常短.是事务级别的缓存: 还是以Book和Category这两个表为例,我们用代码观察一个缓存的存在: 假设现在我要去查询i ...

  3. mybatis的缓存机制(一级缓存二级缓存和刷新缓存)和mybatis整合ehcache

    1.1  什么是查询缓存 mybatis提供查询缓存,用于减轻数据压力,提高数据库性能. mybaits提供一级缓存,和二级缓存. 一级缓存是SqlSession级别的缓存.在操作数据库时需要构造 s ...

  4. mybatis源码分析(7)-----缓存Cache(一级缓存,二级缓存)

    写在前面  MyBatis 提供查询缓存,用于减轻数据库压力,提高数据库性能. MyBatis缓存分为一级缓存和二级缓存. 通过对于Executor 的设计.也可以发现MyBatis的缓存机制(采用模 ...

  5. 为什么CPU缓存会分为一级缓存L1、L2、L3?有什么意义?

    https://baijiahao.baidu.com/s?id=1598811284058671259&wfr=spider&for=pc 简介:CPU缓存是CPU一个重要的组成部分 ...

  6. mybatis缓存,包含一级缓存与二级缓存,包括ehcache二级缓存

    一,引言 首先我们要明白一点,缓存所做的一切都是为了提高性能.明白了这一点下面我们开始进入正题. 二,mybatis缓存概要 ①.mybatis的缓存有两种,分别是一级缓存和二级缓存.两者都属于查询缓 ...

  7. mybati缓存机制之二级缓存配置

    二级缓存配置 在MyBatis的配置文件中开启二级缓存. <setting name="cacheEnabled" value="true"/> 在 ...

  8. 缓存机制总结(JVM内置缓存机制,MyBatis和Hibernate缓存机制,Redis缓存)

    一.JVM内置缓存(值存放在JVM缓存中) 我们可以先了解一下Cookie,Session,和Cache Cookie:当你在浏览网站的时候,WEB 服务器会先送一小小资料放在你的计算机上,Cooki ...

  9. hibernate笔记--缓存机制之 二级缓存(sessionFactory)和查询缓存

    二级缓存(sessionFactory): Hibernate的二级缓存由SessionFactory对象管理,是应用级别的缓存.它可以缓存整个应用的持久化对象,所以又称为“SessionFactor ...

随机推荐

  1. IBM ServerGuide引导盘全系列下载网址

    IBM ServerGuide引导盘全系列下载网址 官网链接 https://www.ibm.com/support/home/docdisplay?lndocid=SERV-GUIDE v9.30 ...

  2. 美式九球比赛规则 (Nine-ball)

    九球比赛规则 (Nine-ball) 九球比赛规则 一.器材: 1.台面规格: a.内沿长254厘米. b.内沿宽127厘米. c.高80厘米. d.角袋口内沿最近距离为10.5厘米(±1毫米),腰袋 ...

  3. Hadoop 的序列化

    1. 序列化 1.1 序列化与反序列化的概念 序列化:是指将结构化对象转化成字节流在网上传输或写到磁盘进行永久存储的过程 反序列化:是指将字节流转回结构化对象的逆过程 1.2 序列化的应用 序列化用于 ...

  4. October 16th 2017 Week 42nd Monday

    The more decisions that you are forced to make alone, the more you are aware of your freedom to choo ...

  5. jQuery 效果函数,jquery文档操作,jQuery属性操作方法,jQuerycss操作函数,jQuery参考手册-事件,jQuery选择器

    jQuery 效果函数 方法 描述 animate() 对被选元素应用“自定义”的动画 clearQueue() 对被选元素移除所有排队的函数(仍未运行的) delay() 对被选元素的所有排队函数( ...

  6. ES6中变量解构的用途—遍历Map结构

  7. HTML5API之获取地理位置详解

    在使用地理位置API之前先来了解一下什么是经度和纬度以及地理位置获取的原理 首先经度指的是南北极的连接线,纬度指的是东西的连接线 地理位置的获取原理是通过IP地址(基于ISP记录,能够知道这个IP地址 ...

  8. BZOJ3632:外太空旅行(最大团,DFS)

    Description 在人类的触角伸向银河系的边缘之际,普通人上太空旅行已经变得稀松平常了.某理科试验班有n个人,现在班主任要从中选出尽量多的人去参加一次太空旅行活动. 可是n名同学并不是和平相处的 ...

  9. 1036. [ZJOI2008]树的统计【树链剖分】

    Description 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w.我们将以下面的形式来要求你对这棵树完成 一些操作: I. CHANGE u t : 把结点u的权值改为t II. ...

  10. 「2017 山东一轮集训 Day5」字符串

    题目 比较神仙的操作啊 首先先考虑一个串的做法,我们有两种:SA或SAM,其中SAM又有两种,拓扑图上的\(dp\)和\(parent\)上随便统计一下 显然这道题\(SA\)和\(parent\)树 ...