缓存是存在内存的数据,为什么我们要用缓存呢,因为缓存的速度比较快,相比较去交互数据库要快很多。
①当你查询的数据长时间不会改变
②查出的数据正确与否不影响任何操作
众所周知mybatis是一个与数据库交互的半自动对象关系映射(ORM)持久层框架,所以加入缓存的机制会很好的提升速度。
① 默认是开启的。
② 在同一个sqlSession会话下的操作都会存入缓存,就是一个请求中查询的数据都会存入缓存。
③ 当会话中,有增删改的操作,并且commit时,缓存就会清空。
④ 没有失效时间,只有生命周期,当会话结束的适合,就会释放掉。

① 默认是关闭的(需要进行配置才能开启)。
② 会话是全局的,sqlSeesionFactory可能包含多个sqlSeesion会话,sqlSeesion之间可以共享数据。当一级缓存关闭或者清除的时候会存进二级缓存。
③ 当会话中,有增删改的操作,并且commit时,缓存就会清空。
④ 有失效时间,cache默认是一小时,每当有数据存进来,就会判断是否超过一小时,如果超过就释放二级缓存。
⑤实体类实现反序列化(Serializable接口)
反序列化:根据字节流中保存的对象状态及描述信息,通过反序列化重建对象。

//全局配置文件 mybatis-configuration.xml 文件中加入
<settings>
<setting name="cacheEnabled" value="true" />
settings>
mybatis:
configuration:
cache-enabled: true
<cache>cache>