缓存
简介:
MyBatis 内置了一个强大的事务性查询缓存机制,它可以非常方便地配置和定制。 为了使它更加强大而且易于配置,我们对 MyBatis 3 中的缓存实现进行了许多改进。默认情况下,只启用了本地的会话缓存,它仅仅对一个会话中的数据进行缓存。
一级缓存
特性:
- 默认就开启了,也可以关闭一级缓存locaICacheScope = STATEMEN
- 作用域是基于sqlSession(默认),一次数据库操作会话,
- 缓存默认实现类PerpetualCache ,使用map进行存储的
key==> hashcode+salid+sql+hashcode+environments+默认id - 查询结束后进行存储
失效情况:
- 不同的sqlSession会使一级缓存失效
- 同一个SqlSession,但是查询语句不一样
- 同一个SqlSession,查询语句一样,期间执行增删改操作
二级缓存
二级缓存是全局作用域缓存,默认是不开启的,需要手动进行配置。
Mybatis提供二级缓存的接口以及实现,缓存实现的时候要求实体类实现Serializable接口,二级缓存在sqlSession关闭或提交之后才会生效。
特性:
- 默认开启了,没有实现
- 作用域:基于全局范围,应用级别。
- 缓存默认实现类PerpetualCache ,使用map进行存储的但是二级缓存根据不同的mapper命名空间多
包了一居map:
org.apache.ibatis. session. Configuration#cacheskey : mapper命名空间value:erpetualcache.map
*keyT-hashcode+salid+sql+hashcode+environments默认id - 事务提交的时候进行存储的(sqlsession关闭的时候)
1、缓存的使用
步骤:
- 全局配置文件中添加如下配置:
<!--开启二级缓存默认是cacheEnabled=true-->
<setting name="cacheEnabled" value="true" />
- 需要在使用二级缓存的映射文件出使用
<cache/>标签标注 - 实体类必须要实现Serializable(序列化接口)
失效:
- 同一个命名空间进行了增删该的操作,会导致二级缓存失效
如果不想失效:可以将SUL的flushCache 这是为false,但是要慎重设置,因为会造成数据脏读问题,除非你能保证查询的数据永远不会执行馏洲 - 让查询不缓存数据到二级缓存中,
- useCache是否需要使用缓存
默认 true使用false不使用 - flushCache 默认是false
- useCache是否需要使用缓存
eviction当缓存达到一定的数量的时候(size的数量),以哪种方式进行回收缓存;
(1)LRU -最近最少使用:移除最长时间不被使用的对象。(默认)
(2)FIFO-先进先出:按对象进入缓存的顺序来移除它们。
(3)SOFT软引用:基于垃圾回收器状态和软引用规则移除对象。
(4)WEAK-弱引用:更积极地基于垃圾收集器状态和弱引用规则移除对象。
flushInterval 刷新时间毫秒
size 可以缓存的数量
readOnly 设置数据是否只读
true读取缓存的数据性能更高,
false默认读取缓存的数据性能更低,
type二级缓存实现类org.apache.ibatis.cache.impl.PerpetualCache (可省略)。

本文主要介绍了MyBatis的一级缓存和二级缓存。一级缓存默认开启,作用域基于sqlSession,查询结束后存储,不同sqlSession、查询语句不同或执行增删改操作会使其失效。二级缓存是全局作用域,默认不开启,需手动配置,sqlSession关闭或提交后生效,增删改操作会导致其失效。
618

被折叠的 条评论
为什么被折叠?



