文档章节

博为峰JavaEE技术文章 ——MyBatis 缓存(2)一级缓存与二级缓存

博为峰教研组
 博为峰教研组
发布于 2017/02/14 19:25
字数 393
阅读 16
收藏 0

上一节我们学习Mybatis的缓存使用了<cache>元素,在mapper文件中进行设置,这种配置属于Mybatis的二级缓存。Mybatis本身具有一种缓存机制,是针对与SQLsession级别的缓存,称之为一级缓存。本节小博老师给大家介绍下一级缓存和二级缓存的区别。

所谓一级缓存是指,MyBatis执行SQL语句之后,该语句及结果会被缓存,以后再执行这条语句的时候,会直接从缓存中拿结果,而不是再次执行SQL。一级缓存的作用域是SqlSession。

这段代码只会执行一次sql语句查询。第二次读取user对象时,不再执行sql语句查询,直接从缓存中读取。

但是如果是从不同的session中获取相同的user对象呢?代码做如下修改:

我们发现,控制台打印了两次sql语句查询:

 

上节课我们配置的<cache>元素是二级缓存,二级缓存的作用域是全局,换句话说,二级缓存不受SqlSession控制,但需要记住一点:二级缓存在SqlSession关闭或提交之后才会生效。

在mapper中加入<cache/>元素,然后对上面的代码略作修改:

在第一个session查询完成后,需要commit或者close,否则仍然会执行两次sql查询。观察控制台,我们发现Mybatis只执行了一次sql查询:

 

© 著作权归作者所有

共有 人打赏支持
博为峰教研组
粉丝 50
博文 1224
码字总数 479077
作品 0
黄浦
程序员
技术专题讨论:如何对 JPA 或者 MyBatis 进行技术选型

在我们平时的项目中,大家都知道可以使用 JPA 或者 Mybatis 作为 ORM 层。对 JPA 和 Mybatis 如何进行技术选型? 下面看看大精华总结如下: 最佳回答 首先表达个人观点,JPA必然是首选的。 ...

后海
06/27
0
0
图解 & 深入浅出 JavaWeb:Servlet 再说几句

Writer :BYSocket(泥沙砖瓦浆木匠) 微 博:BYSocket 豆 瓣:BYSocket FaceBook:BYSocket Twitter :BYSocket 上一篇的《 Servlet必会必知 》受到大家一致好评 — (感谢 读者 及 OSC 推荐...

泥沙砖瓦浆木匠
2015/09/03
0
13
spring-data-jpa+hibernate 各种缓存的配置演示

本文所有测试用代码在https://github.com/wwlleo0730/restjplat 的分支addDB上 目前使用在使用spring-data-jpa和hibernate4的时候,对于缓存关系不是很清楚,以及二级缓存和查询缓存的各种配...

wwlleo123
2014/03/18
0
0
Java面似宝典--Java Web(JSP、Servlet、各常用框架SSH、MyBatis等)

1、什么MVC模式?说说你对MVC的理解。 2、工作中经常用到的框架有哪些?它们各自的优缺点是什么? 3、说说Struts、Spring中的设计模式。 4、拦截器和过滤器两者的区别是什么? 5、简述一下,...

瓜子葫芦侠
2014/03/26
0
0
动态高速缓存技术(缓存jsp、servlet等动态数据)

(jsp、servlet) 动态高速缓存技术 缓存一般在大型web端应用上使用教多常见,今日读了ibm 开发者社区中的一篇关于 动态缓存技术的文章,发发言,也是记录下内容。 主要流程: 缓存主要对象: ...

so1y
2011/03/22
0
2

没有更多内容

加载失败,请刷新页面

加载更多

Spring Boot 使用parent方式引用时 获取值属性方式默认@

采用官网提供的 引入依赖时,application.properties中的值变量,无法通过${}获取,这是由于Spring Boot 已经将字符方式调整为 <resource.delimiter>@</resource.delimiter>。故如果在,工程中...

翱翔fly
23分钟前
1
0
HTTPS证书验证流程及SSL证书生成步骤【附nginx开启https配置】

------------------------------------------------------------ HTTPS证书验证流程(极简化版) 1.客户端向服务端请求证书(server.crt) 2.服务端下发证书(server.crt) 3.客户端用预制的...

xiaomin0322
24分钟前
1
0
预编译sql语句和参数化sql能有效防止——sql注入攻击——

预编译和参数化处理sql原理类似: 参数化处理sql 是将参数进行了字符串化处理,把参数中的单引号,井号#,等都做了转义处理,进而在执行sql语句时不会被当做sql中的定界符和指定符来执行。 ...

fang_faye
25分钟前
1
0
springboot最全配置解释

​​​​​​​# ----------------------------------------# 核心属性# ----------------------------------------# 文件编码banner.charset= UTF-8# 文件位置banner.locati...

废柴大叔
27分钟前
82
1
(大致了解下)从单机到2000万QPS: 知乎Redis平台发展与演进之路

导读:知乎存储平台团队基于开源Redis 组件打造的知乎 Redis 平台,经过不断的研发迭代,目前已经形成了一整套完整自动化运维服务体系,提供很多强大的功能。本文作者是是该系统的负责人,文...

Ocean_K
34分钟前
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部