缓存
简介
引入:
查询数据:需要连接数据库--好资源
解决:把第一次查询的结果放到一个地方,再次查询时直接在这个地方访问就可以(内存--缓存),不需要在访问数据库
什么是缓存?
存在内存中的临时数据
将用户经常查询的数据放在缓存(内存)中,用户去查询数据就不用从磁盘上(关系型数据库查询文件)查询,从缓存中查询,从而提高查询效率,解决了高并发系统的性能问题
为什么使用缓存?
减少和数据库的交互次数,减少系统开销,提高系统效率
什么样的数据可以使用缓存?
经常查询并且不经常改变的数据
Mybatis缓存
Mybatis包含一个非常强大的查询缓存特性,它可以非常方便地定制和配置缓存。缓存可以极大的提升查询效率。
Mybatis系统中默认定义了两级缓存:一级缓存和二级缓存
默认情况下,只有一级缓存开启。(SqlSession级别的缓存,也称为本地缓存)
二级缓存需要手动开启和配置,它是基于namespace级别的缓存。
为了提高扩展性,Mybatis定义了缓存接口Cache,我们可以通过实现Cache接口来自定义二级缓存。
一级缓存
一级缓存也叫本地缓存:
一级缓存是默认开启的,不能关闭
与数据库同一次会话期间查询到的数据会放在本地缓存中
以后如果需要获取相同的数据,直接从缓存中拿,没必要再去查询数据库
一级缓存相当于一个Map
测试步骤:
开启日志
测试执行
查看日志和运行结果
在这里插入图片描述
缓存失效的情况:
增删改操作可能会刷新数据库中的数据,因此会进行缓存的刷新
查询不同的数据
手动清理缓存
二级缓存
二级缓存也叫全局缓存,一级缓存作用域太低了,所以诞生了二级缓存
基于namespace级别的缓存,一个名称空间,对应一个二级缓存
工作机制:
一个会话查询一条数据,这个数据就会被放在当前会话的一级缓存中 如果当前会话关闭了,这个会话对应的一级缓存就没了;但是我们想要的是,会话关闭了,一级缓存中的数据被保存到二级缓存中; 新的会话查询信息,就可以从二级缓存中获取内容; 不同的mapper查出的数据就会放在自己对应的缓存(map)中
测试步骤:
-
显示的开启全局缓存(二级缓存),虽然默认的就是开启的
<!-- 在Mybatis-config.xml中配置 显示的开启全局缓存(二级缓存)--> <setting name="cacheEnabled" value="true"/>
-
在当前的XxMapper.xml文件中使用二级缓存
<cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/> 一般: <cache/>
错误:Cause: java.io.NotSerializableException: com.my.pojo.User(实体类序列化)
使用二级缓存要注意:
所有数据刚开始都会先放在一级缓存中,等到一级缓存sqlSession关闭后,才会将数据存放到二级缓存中(前提是开启了二级缓存)
缓存原理
自定义缓存-ehcache(了解)
标签:缓存,一级,查询,二级缓存,Mybatis,数据 From: https://www.cnblogs.com/kuangshenmentu/p/17761542.html