1.缓存
1.1简介
- 什么是缓存[Cache]
- 存在内存中的临时数据。
- 将用户经常查询的苏剧放在缓存中,用户查数据就不用再从磁盘上查了,可以从缓存中查,提高查询效率,解决了高并发系统的性能问题。
- 缓存的好处
- 减少和数据库交互的次数,减少系统开销,提高系统效率
- 什么数据适合使用缓存
- 经常查询并且不经常改变的数据
1.2Mybatis缓存
- Mybatis包含一个非常强大的查询缓存特性,方便定制和配置缓存,缓存可以极大的提升查询效率
- Mybatis系统中默认定义两级缓存:一级缓存和二级缓存
- 默认情况下,只有一级缓存开启。(SglSession级别的缓存,也称为本地缓存)
- 二级缓存需要手动开启和配置,他是基于namespace级别的缓存。
- 为了提高扩展性,MVBatis定义了缓存接口Cache。我们可以通过实现Cache接口来自定义二级缓存
1.3一级缓存
-
一级缓存也叫本地缓存:sqlsession
- 与数据库同一次会话期间查询到的数据回放在本地缓存中
- 以后如果需要获取相同数据可以直接从缓存里面拿,没必要再去数据库查
-
缓存失效的情况:
- 查询不同的东西(类似于传递不同参数进去查询)
- 增删改操作,可能会改变原来的数据,所以必定会刷新缓存
- 查询不同的Mapper.xml
- 手动清理缓存(sqlSession.clearCache();)
1.4二级缓存
- 二级缓存也叫全局缓存,一级缓存作用域太低,所以有了二级缓存
- 基于namespace级别的缓存,一个名称空间,对应一个二级缓存
- 工作机制
- 一个会话查询一条数据,这个数据就会被放在当前会话的一级缓存中。
- 如果当前会话关闭了,这个会话对应的一级缓存就没了;但是我们想要的是,会话关闭了,一级缓存中的数据被保存到二级缓存中。
- 新的会话查询信息,就可以从二级缓存中获取内容。
- 不同的mapper查出的数据会放在自己对应的缓存(map)中。
步骤:
1.开启全局缓存(在mybatis-config.xml里面配置)
<!-- 显示的开启全局缓存-->
<setting name="cacheEnabled" value="true"/>
2.在要使用二级缓存的Mapper中开启
<!-- 在当前Mapper.xml中使用二级缓存-->
<cache/>
也可以自定义参数
<cache eviction="FIFO" flushInterval="6000" size="512" readOnly="true"/>
- eviction:清除策略,设为FIFO先来先服务
- flushInterval:每6000刷新一次缓存
- size:最多可以存储的对象引用
- readOnly:设置缓存的只读属性
3.测试
要记得将实体类序列化,否则可能会报错
public class User implements Serializable
总结:
- 只要开启二级缓存,在同一个Mapper下就有效
- 所有数据都会先放在一级缓存中
- 只有当会话(sqlsession)提交,或者关闭的时候,才会提交二级缓存
1.5缓存原理
用户查询是先从二级缓存里面查,再到一级缓存,都没有再去查数据库。
1.6自定义缓存-encache
1.导包
<!-- https://mvnrepository.com/artifact/org.mybatis.caches/mybatis-ehcache -->
<dependency>
<groupId>org.mybatis.caches</groupId>
<artifactId>mybatis-ehcache</artifactId>
<version>1.1.0</version>
</dependency>
2.在mapper中指定使用ehcache缓存实现
<!-- 使用自定义缓存-->
<cache type="org.mybatis.caches.ehcache.EhcacheCache"/>
完结撒花!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/84167.html