Mybatis提供缓存查询功能,用于减轻数据库压力,提升数据查询能力。

Mybatis中定义了两级缓存:包括一级缓存与二级缓存。示意图如下所示:

一、一级缓存

一级缓存的特点

  • 每一个SqlSession都有一个一级缓存,且它们的缓存数据区域之间互不影响。
  • 一级缓存是默认开启的,开发人员不能关闭。

一级缓存又称为会话缓存,是SqlSession级别的缓存,它的作用域是同一个SqlSession,在查询数据时会创建SqlSession对象,其中会有一个HashMap进行数据的缓存,在同一个SqlSession执行两次相同的sql语句的过程中,第一次查询完毕会将查询的数据写到缓存中,第二次会直接从缓存中获取查询结果,不用去数据库进行查询,提升了查询效率。查询过程如下图所示:

如图所示,SqlSession进行查询的过程如下:

  1. 在发起查询过程中,会首先去一级缓存进行查询,若没有,则去数据库进行数据查询。
  2. 得到查询的数据结果,将其存储到一级缓存中。
  3. 第二次进行相同sql的查询时,会先去缓存中进行数据查询,若有,则直接从缓存中获取数据。

Mybatis一级缓存的内部,是以HashMap的方式进行存储的,其中Key值为hashCode+sqlId+Sql语句,value为从数据库查出来的数据结果映射成的Java对象。

注意

在上图中发现在进行了修改,添加,删除用户的操作时,SqlSession会执行commit操作刷新SqlSession中的一级缓存。目的是为了更新缓存中的数据信息,避免脏读

一级缓存失效的情况:同一个用户使用两个SqlSession,

二、二级缓存

二级缓存的特点

  • 二级缓存默认是关闭的,需要开发人员开启。
  • 二级缓存是多个SqlSession共享的,其作用域是mapper的同一个namespace,可以理解为它针对的是一个表的缓存
  • 一个SqlSession对象将要被销毁时,MyBatis会自动将这个SqlSession中与当前表关联的数据存放到这个二级共享缓存中

二级缓存又称全局缓存,它是根据mapper的namespace划分的,相同namespace的mapper查询数据放在同一个区域,如果使用mapper代理方法每个mapper的namespace都不同,此时可以理解为二级缓存区域是根据mapper划分。它的查询过程如下图所示:

与一级缓存类似,每次查询会先从缓存区域找,如果找不到再从数据库查询,并将查询到数据将数据写入缓存。SqlSession执行insert、update、delete等操作commit提交后会刷新缓存区域。同时它的存储也是基于HashMap的,key值也为hashCode+sqlId+Sql语句。

三、缓存相关属性

1、开启/禁用二级缓存

二级缓存的开启/禁用是在核心配置文件中的<settings>标签中配置的。

<settings>
<!-- 通知MyBatis框架开启二级缓存 -->
<!-- <setting name="cacheEnabled" value="true"/> --> <!-- 通知MyBatis框架关闭二级缓存 -->
<setting name="cacheEnabled" value="false"/>
</settings>

2、useCache属性

useCache配置在mapper.xml文件中,且只会出现在select标签中。useCache默认值就是true,当置false时,对于一级缓存没有影响,只是与SqlSession相关联的查询结果在第一个SqlSession关闭时是不会放到二级缓存中。

<select id="findUsertById"  resultType="user" useCache="true">

3、刷新缓存

flushCache是刷新缓存的属性,它配置在mapper.xml文件中,它用于决定当前sql执行完毕后,是否会刷新(清空)缓存。flushCache可以配置在添加,更新,删除,查询标签中。

  • flushCache配置在添加,更新,删除标签中时,它的默认值为true。

    • 当flushCache为true时,在执行过程中会清空一级缓存数据/清空二级缓存对应的mapper.xml所有数据,会即时修改缓存中的数据,避免出现脏读。
    • 当flushCache为false时,在执行过程中会清空一级缓存数据/不会清空二级缓存数据
  • flushCache配置在<select>标签中时,它的默认值为false。

    • 当flushCache为false时,一级缓存和二级缓存都可以使用
    • 当flushCache为true时,查询结果不会保存到一级缓存和二级缓存

4、clearCache()方法

sqlSession.clearCache()只会清空当前会话的一级缓存,不会影响数据保存到二级缓存

参考了:https://www.cnblogs.com/zhangzongle/p/6211285.html

Mybatis中的缓存的更多相关文章

  1. [原创]关于mybatis中一级缓存和二级缓存的简单介绍

    关于mybatis中一级缓存和二级缓存的简单介绍 mybatis的一级缓存: MyBatis会在表示会话的SqlSession对象中建立一个简单的缓存,将每次查询到的结果结果缓存起来,当下次查询的时候 ...

  2. SSM-MyBatis-17:Mybatis中一级缓存(主要是一级缓存存在性的证明,增删改对一级缓存会造成什么影响)

    ------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 缓存------------------------------------------> 很熟悉的一个 ...

  3. mybatis中的缓存问题

    关于mybatis基础我们前面几篇博客已经介绍了很多了,今天我们来说一个简单的问题,那就是mybatis中的缓存问题.mybatis本身对缓存提供了支持,但是如果我们没有进行任何配置,那么默认情况下系 ...

  4. 关于mybatis中一级缓存和二级缓存的简单介绍

    关于mybatis中一级缓存和二级缓存的简单介绍 mybatis的一级缓存: MyBatis会在表示会话的SqlSession对象中建立一个简单的缓存,将每次查询到的结果结果缓存起来,当下次查询的时候 ...

  5. Mybatis中的缓存管理

    目录 Mybatis中的缓存管理 查询缓存工作原理: 配置缓存: 默认配置: 使用二级缓存: 刷新缓存过程: 配置EHcache 产生脏数据 使用原则: Mybatis中的缓存管理 查询缓存工作原理: ...

  6. SSM-MyBatis-18:Mybatis中二级缓存和第三方Ehcache配置

    ------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 二级缓存 Mybatis中,默认二级缓存是开启的.可以关闭. 一级缓存开启的.可以被卸载吗?不可以的.一级缓存 ...

  7. MyBatis中的缓存1

    1.应用程序和数据库交互的过程是一个相对比较耗时的过程 2.缓存存在的意义:让应用程序减少对数据库的访问,提升程序运行的xiaolv 3.MyBatis中默认SqlSession缓存开启 3.1  同 ...

  8. MyBatis中二级缓存和延时加载同时开启的问题

    首先,二级缓存默认不开启! 要配置 <setting name="cacheEnabled" value="true"/> 在MyBatis中:一级 ...

  9. 一次读懂mybatis中的缓存机制

    缓存功能针对于查询(没听说果UPDATE,INSERT语句要缓存什么,都是直接执行的) 默认情况下,mybatis会启用一级缓存. 如果使用同一个session对象调用了相同的SELECT语句,则直接 ...

随机推荐

  1. [HTML] css3 输入框input类型为number时,去掉上下箭头方式

    <input type="number" ...> <style> input::-webkit-outer-spin-button, input::-we ...

  2. 重识 PWA 进阶到 workbox3

    看到PWA,似曾相识,但又感觉很模糊,于是乎,又重新翻阅文档,学习了一遍,顺便把相关知识学习了一下,比如service worker,workbox3. PWA 概念: 全称:Progressive ...

  3. nginx和tomcat访问图片和静态页面的配置方法

    生产环境下,有时候需要访问图片,正常需要应用ftp.nginx等配套使用,但是有时候为了简化,可以用以下的两种简单的访问,说实话,就是为了偷懒,但是效果是能有的,这就行了,所以今天做这个简化版的方便大 ...

  4. 【xsy2913】 enos 动态dp

    题目大意:给你一棵 $n$个点 以 $1$为根 的树,每个点有$ 0,1,2 $三种颜色之一,初始时整棵树的颜色均为 $0$. $m$ 次操作, 每次操作形如: 1 x y c : 将 $x$到$y$ ...

  5. EXECUTE 后的事务计数指示缺少了 COMMIT 或 ROLLBACK TRANSACTION 语句。上一计数 = 1,当前计数 = 2

    理解这一句话: 一个begin tran会增加一个事务计数器,要有相同数量的commit与之对应,而rollback可以回滚全部计数器 这个错误一般是出现在嵌套事务中. 测试环境 sql 2008 例 ...

  6. spring boot 中使用swagger 来自动生成接口文档

    1.依赖包 <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swa ...

  7. mysql添加类似oracle的伪列及查看表信息

    sql格式: AS rownum, table_name.* ) r, table_name; AS rownum, table_name.字段1, table_name.字段2, table_nam ...

  8. MySQL笔记(1)---MySQL体系结构和存储引擎

    1.前言 本系列记录MYSQL数据库的一些结构和实现特点,方便查询. 2.基本概念 数据库:物理操作系统文件或者其他形式文件类型的集合.MySQL中数据库文件可以是frm.MYD.MYI.ibd结尾的 ...

  9. 在 ASP.NET MVC 中使用异步控制器

    线程池 一直想把项目改写成异步,但是ASP.NETMVC3下写的过于繁琐,.NET 4.5与ASP.NET MVC下代码写起来就比较简单了, MS好像也一直喜欢这样搞,每一个成熟的东西,都要演变好几个 ...

  10. JavaScript -- Window-Interval

    -----031-Window-Interval.html----- <!DOCTYPE html> <html> <head> <meta http-equ ...