缓存的概念:
- 存储在内存当中的数据
- 将用户常使用的数据存放在缓存(内存)当中,用户查询数据就不用从磁盘(关系型数据库文件)当中查询,从缓存当中查询,从而提高查询效率,解决了高并发系统的性能问题
- 减少和数据库的交互次数,减少系统开销,提高系统效率
- 经常查询并且不常改变的数据
mybatis系统当中默认定义了两级缓存:一级缓存和二级缓存
1)一级缓存:
- sqlSession级别的
- 存在于 sqlSession的生命周期中。
- sqlSession.commit()之后,会重新发送SQL进行查询,即缓存消失
- 查询相同数据,在不commit和close的前提下,只会发送一次SQL,后面的都通过前者查出的数据来直接使用,提高了效率
- 缓存失效的几种情况:
- sqlSession不同
- sqlSession相同,查询条件不同
- sqlSession相同,两次查询之间执行了增删改操作!
- sqlSession相同,手动清除一级缓存
没写commit,查询相同数据,只发送了一次SQL,炒同样的菜,没必要洗锅了
加上commit,发送了两次SQL
2)二级缓存
- 工厂级别的 :namespace级别
- 存在于 SqlSessionFactory 的生命周期中。
在UserMapper.xml配置文件声明使用二级缓存
-
<!--使用二级缓存--> <cache eviction="FIFO" #收回策略 flushInterval="6000" #刷新间隔 size="512" #引用数目 readOnly="true"/> #只读
- 在mybatis-config.xml配置文件中开启二级缓存,默认为true,开启
<!‐‐ 开启二级缓存 ‐‐> <settings> <!--开启二级缓存--> <setting name="cacheEnabled" value="true"/> </settings>
- 有可能会报类未序列化的错误,此时你需要去让类实现Serializable接口
- 二级缓存,只要工厂没有关闭,通过这个工厂得到的sqlSession,都会存在缓存
下面这张图你会发现,我们通过工厂得到了两个sqlSession,但是由于工厂并没有关闭
二级缓存的存在让我们在查询相同数据,或者说调用同一个方法时,只发送了一次SQL