您的位置:首页 > 其它

Mybatis一级和二级缓存

2017-11-28 11:49 253 查看

Mybatis一级和二级缓存

正如大多数持久层框架一样,MyBatis 同样提供了一级缓存和二级缓存的支持

1.Mybatis一级缓存为sqlSession级别的缓存 默认开启 相同的sqlsession对象 查询相同条件的结果时 存在一级缓存只会查询一次,sqlSession关闭后缓存失效 调用cleanCache后 缓存被清除,执行过增删改后缓存会被清除

如果缓存中有数据就不用从数据库中获取,大大提高系统性能。

2.二级缓存为sqlSessionFactory级别的缓存 默认不开启

开启方式为如下:

<settings>
<setting name="cacheEnabled" value="true"/>
</settings>
在映射文件中添加cache标签 默认使用LRU算法 也可以不适用默认  的配置
<cache eviction="FIFO"  //回收策略为先进先出
flushInterval="60000" //自动刷新时间60s
size=“512” //最多缓存512个引用对象 readOnly="true"/> //只读


3.

* 一级缓存 同一个session对象针对同一份数据的查询 产生的缓存

* 第一次查询时 调用数据 获取数据后

* 通过session设置到一级缓存中

* 第二次查询时 通过session一级缓存判断是否存在 相同主键的数据值

* 如果存在 直接返回引用 否则查询数据库

二级缓存 同一个sessionFactory下的不同session 可以共享数据

4.mybatis默认缓存类 FifoCache

内存数据不足时 需要一种机制 保证 内存不出现溢出 需要将旧的数据清除 最 先加入的数据 最先清除

LRU 最近使用次数最少的 被优先清除

LFU 最近一段时间内使用次数最少

5.MyBatis会在一次会话的表示—-一个SqlSession对象中创建一个本地缓存(local cache),对于每一次查询,都会尝试根据查询的条件去本地缓存中查找是否在缓存中,如果在缓存中,就直接从缓存中取出,然后返回给用户;否则,从数据库读取数据,将查询结果存入缓存并返回给用户。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: