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),对于每一次查询,都会尝试根据查询的条件去本地缓存中查找是否在缓存中,如果在缓存中,就直接从缓存中取出,然后返回给用户;否则,从数据库读取数据,将查询结果存入缓存并返回给用户。