在mybatis中可以本地缓存数据库返回的数据,避免第二次访问时还需要重新访问数据库,提升效率又降低数据库负载。
缓存有两种方式:
一、一级缓存
一级缓存指的是SqlSession的缓存,这一缓存功能是自动开启的,其声明周期从得到SqlSession对象起,至关闭SqlSession对象时结束。
SqlSession session = factory.openSession();
----------------------------------------
session.close();
第二次重复调用业务代码,会发现log4j日志显示又重新执行了一遍sql访问数据库。
二、二级缓存
做到从不同的一级缓存中共享数据,也就是在做一级缓存的时候,同步了一份数据到二级缓存中,这样一级缓存关闭后,其他的一级缓存也可以访问到这个二级缓存里的数据。
二级缓存指的是SqlSessionFactory的缓存,该功能需要手动开启
配置mapper
<mapper namespace="接口路径">
<cache eviction="FIFO"
flushInterval="60000"
size="512"
readOnly="true"/>
</mapper>
cache元素用来开启当前mapper的namespace下的二级缓存,这里我用到的cache标签属性说明:
- eviction: 决定二级缓存中,缓存的对象从缓存中移除的策略。FIFO:回收策略为先进先出;
- flushInterval: 刷新缓存的事件间隔,单位:毫秒,这里每隔10分钟刷新一次缓存,在调用语句时生效。
- size: 缓存对象的个数
- readOnly: 决定缓存是否是只读的
第二次重复调用业务代码,会发现log4j日志已不显示调用sql的语法。
对于Cache元素里属性的详细说明:
flushInterval:刷新间隔,可以被设置为任意的正整数,而且它们代表一个合理的毫秒形式的时间段,默认情况下是不设置的,也就是没有刷新间隔,缓存仅仅调用语句时刷新。
size:缓存数目,可以被设置为任意正整数,要记住你的缓存对象数目和你运行环境可用内存资源数目,默认值是1024.
readOnly:只读,属性可以被设置为true或false,只读的缓存会给所有调用者返回缓存对象的相同实例,因此这些对象不能被修改。这提供了很重要的性能优势,可读写的缓存会返回缓存对象的拷贝(通过序列化),这会慢一些,但是安全,因此默认是false。
eviction:收回策略,默认为LRU,有如下几种:
LRU:最近最少使用的策略,移除最长时间不被使用的对象。
FIFO:先进先出策略,按对象进入缓存的顺序来移除它们。
SOFT:软引用策略,移除基于垃圾回收器状态和软引用规则的对象。
WEAK:弱引用策略,更积极地移除基于垃圾收集器状态和弱引用规则的对象。
注意:使用二级缓存时,与查询结果映射的java对象必须实现java.io.Serializable接口的序列化和反序列化操作,如果存在父类,其成员都需要实现序列化接口,实现序列化接口是为了对缓存数据进行序列化和反序列化操作,因为二级缓存数据存储介质多种多样,不一定在内存,有可能是硬盘或者远程服务器。
例如:
public class Student implements Serializable {}
还需要注意的是:
-
重要的数据不应该放在缓存中
-
实现二级缓存:需要用同一个SessionFactory,开启不同的Session