mybatis学习笔记(6) ------ 缓存
缓存
缓存就是暂存数据的地方,mybatis提供缓存机制,将数据存储在缓存中,下次查询的时候,若缓存中存在需要的数据,就无需去数据库中查找,可以提升性能。
一级缓存
在SqlSession中维护一个缓存,用来用来存放查找出来的数据,因此一级缓存只在同一个SqlSession对象中有效,不同的SqlSession都有属于自己的HashMap,都有属于自己的缓存。当调用commit方法之后,缓存会被清空。
演示
@Test
public void test8(){
SqlSession sqlSession = factory.openSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
User u1 = mapper.search(1);
System.out.println(u1);
System.out.println("=================");
//sqlSession.commit();
User u2 = mapper.search(1);
System.out.println(u2);
}
第一次会执行sql语句,第二次不会执行sql语句,直接从缓存中获取。但当注释解开之后,则第二次也会执行sql语句。
注: 当select元素中将flushCache设置为true后,也会刷新缓存,这个值默认是false。
二级缓存
- 需要手动开启缓存
<!--开启二级缓存总开关,默认为true-->
<setting name="cacheEnabled" value="true"/>
- 对应的映射文件中开启缓存,在select标签中开启缓存
<cache/>
useCache="true" : 默认为true,只与二级缓存有关
- 主配置文件中开启二级缓存
多个SqlSession共用一个SqlSessionFactory
当sqlSession执行close方法,就会将查询的内容存入二级缓存中,下一次不同的sqlSession可以直接去缓存中找数据,找不到再去数据库中查。
每一次增删改之后,都会刷新缓存,一二级缓存都会被刷新。