为了减轻数据压力,提高数据库的性能,我们往往会需要使用缓存。MyBatis为我们提供了一级缓存和二级缓存。

  (1)一级缓存是SqlSession级别的缓存,在操作数据库的时候需要创建一个SqlSession,其中有一个HashMap,用于存储缓存数据。不同的SqlSession之间,其缓存数据的HashMap是不同的;

  (2)二级缓存是Mapper级别的缓存,多个SqlSession去操作同一个Mapper中的SQL语句,则这些SqlSession可以共享二级缓存,即二级缓存是跨SqlSession的。

  MyBatis的一级缓存和二级缓存的结构如下图所示:

1、一级缓存

  我们通过一个例子来理解一级缓存,如下图所示:
  (1)当我们第一次查询ID为1的用户信息时,先去缓存中查找缓存中是否缓存有ID为1的用户信息,发现没有,则去数据库中查询,并将查询结果存储到缓存中;
  (2)第二次查询ID为1的用户信息时,去缓存中查找,发现有缓存的数据,因此从缓存中直接取出数据使用;
  (3)如果对数据库中的数据进行了修改、添加或删除操作并执行了commit之后,会清空一级缓存中的数据(这样做的目的是为了让缓存中存储的永远是最新的数据,避免脏读);
  (4)当我们第三次查询ID为1的用户时,先去缓存中查找,如果有则取出来直接用,如果没有则从数据库中查询,然后重新缓存到缓存中。
  MyBatis默认支持一级缓存,不需要在配置文件中进行配置。

2、二级缓存

  二级缓存的原理与一级缓存的原理相似,都是有则取出来直接使用,无则从数据库中查询出来后存储到缓存中,如果中途进行了commit操作则清空缓存。其基本流程如下图所示:
  MyBatis中的二级缓存默认是关闭的,如果我们想要使用二级缓存,则需要对其进行配置:
  (1)在SqlMapConfig.xml文件中配置二级缓存的总开关,代码如下:
<settings>
<!-- 开启二级缓存(默认是开的,这里写出来是为了方便代码维护) -->
<setting name="cacheEnabled" value="true" />
</settings>

  (2)在XXXMapper.xml文件中开启二级缓存,代码如下:

<!-- 开启本mapper所在namespace的二级缓存 -->
<cache />

  (3)如果想要对某个POJO中的数据进行二级缓存,则需要将其序列化:让这个POJO类实现Serializable接口(这样做的原因是因为二级缓存的数据存储介质是多种多样的,不一定只在内存中,也可能在硬盘中,甚至是远程传输,因此我们将其序列化,以便将来对其进行反序列化)。

  通过以上三个步骤的操作,我们就完成了二级缓存的配置,在XXXMapper这个Mapper中的所有数据就都绑定了二级缓存机制。
  如果我们的某个SQL语句不需要进行二级缓存,但这个SQL所在的Mapper已经配置了二级缓存,那么我们只需要在这个statement上设置useCache属性为false,就可以关闭这个SQL语句的二级缓存,代码如下:
<select id="selectOrderUserType" resultType="bean_order_user_type" useCache="false">

  当然,MyBatis之所以默认不开启二级缓存,是因为二级缓存有一定的局限性。试想,一个数据表中存储着上亿条数据,如果我们开启了二级缓存,那么这上亿条数据就都存储到了二级缓存中,现在如果我们对其中的一条数据进行了修改并commit提交,那么这上亿条数据就被清空出缓存了,即有时候使用二级缓存的命中率极低。这种情况也是有解决方案的,就是使用一些比较优秀的缓存框架,或使用三级缓存。

 

【JavaEE】之MyBatis查询缓存的更多相关文章

  1. Mybatis学习记录(七)----Mybatis查询缓存

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

  2. 八 mybatis查询缓存(一级缓存,二级缓存)和ehcache整合

    1       查询缓存 1.1     什么是查询缓存 mybatis提供查询缓存,用于减轻数据压力,提高数据库性能. mybaits提供一级缓存,和二级缓存.

  3. Spring+SpringMVC+MyBatis深入学习及搭建(八)——MyBatis查询缓存

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6956206.html 前面讲到:Spring+SpringMVC+MyBatis深入学习及搭建(七)——My ...

  4. mybatis查询缓存——(十三)

    1.     mybatis缓存介绍 如下图,是mybatis一级缓存和二级缓存的区别图解: mybatis提供查询缓存,用于减轻数据压力,提高数据库性能. mybaits提供一级缓存,和二级缓存.

  5. apache ignite系列(九):使用ddl和dml脚本初始化ignite并使用mybatis查询缓存

    博客又断了一段时间,本篇将记录一下基于ignite对jdbc支持的特性在实际使用过程中的使用. 使用ddl和dml脚本初始化ignite 由于spring-boot中支持通过spring.dataso ...

  6. (十二)mybatis 查询缓存

    目录 什么是查询缓存 图解查询缓存 一级缓存 二级缓存 禁用二级缓存 刷新缓存 二级缓存应用场景 二级缓存局限性 什么是查询缓存 mybatis 在查询数据的时候,会将数据存储起来,下次再次查询相同的 ...

  7. mybatis 查询缓存问题

    <settings> <setting name="localCacheScope" value="STATEMENT" /> < ...

  8. 【JAVA - SSM】之MyBatis查询缓存

    为了减轻数据压力,提高数据库的性能,我们往往会需要使用缓存.MyBatis为我们提供了一级缓存和二级缓存. (1)一级缓存是SqlSession级别的缓存,在操作数据库的时候需要创建一个SqlSess ...

  9. mybatis查询缓存

    一级缓存针对每个sqlSession进行缓存,sqlSession销毁,一级缓存就不存在. ,使用Map存储了sql执行查询结果集(java对象) 二级缓存针对每个map的namespace进行缓存. ...

随机推荐

  1. 微信授权就是这个原理,Spring Cloud OAuth2 授权码模式

    上一篇文章Spring Cloud OAuth2 实现单点登录介绍了使用 password 模式进行身份认证和单点登录.本篇介绍 Spring Cloud OAuth2 的另外一种授权模式-授权码模式 ...

  2. CSP2019知识点整理

    也算是接下来二十天的复习计划吧 仅止于联赛难度左右 基础算法 字符串 char[] cstring memset() 输入无& gets(), fgets(stdin, ,); strcmp, ...

  3. 关于 typeof 的暂时性死区,了解一下

    将知识转化为能力,核心是掌握20%行业核心技能,把学习培养成习惯,持续深耕,用能力解决问题,方能持续成长!那么基础好,就是必须条件. 最近看 数据类型,知道数据类型判断有三种方式,typeof 是其中 ...

  4. 题解【洛谷】CF134A

    题解 CF134A [Average Numbers] 这题就是简单的模拟. 只不过要优化一下常数什么的 思路: 为了不浪费时间总是取平均数,直接用一个 S 储存总和,每次都减去 a_i​ 再除以 n ...

  5. [Neo4j]Conda虚拟环境中安装python-igraph

    neo4j算法需要用到python-igraph包,但试过很多方法,都失败了 pip install python-igraph 安装失败, 提示C core of igraph 没有安装. 在con ...

  6. QA:无重复字符的最长子串

    无重复字符的最长字串 leetcode地址:https://leetcode-cn.com/problems/longest-substring-without-repeating-character ...

  7. WeihanLi.Npoi 近期更新

    WeihanLi.Npoi 近期更新 Intro 最近对我的 NPOI 扩展做了一些改变,一方面提高性能,一方面修复bug,增加一些新的功能来让它更加好用,前几天发布了 1.5.0 版本,下面来介绍一 ...

  8. 【实用工具】这些你不得不知道的chrome插件,让你事半功倍

    平时chrome插件用多了,发现在工作中有很多插件特别好用,让你事半功倍.于是我抽时间整理了一些非常好用的chrome插件分享给大家,其中有些插件是我已经离不开,每天都在用的.希望这篇文章能帮助你找到 ...

  9. m99 然而并没有想出来标题!

    这是放假回来的第一次考试,如同往常一样,我每逢放假回来第一次考试就会废掉,这次也不例外 这次不想粘成绩,因为实在是rp没了! 之前的几次都是别人在CE等等被lemon砍分,而我被lemon多测分. 但 ...

  10. 浅谈OI中的底层优化!

    众所周知,OI中其实就是算法竞赛,所以时间复杂度非常重要,一个是否优秀的算法或许就决定了人生,而在大多数情况下,我们想出的算法或许并不那么尽如人意,所以这时候就需要一中神奇的的东西,就是底层优化: 其 ...