前言:
为数据库的查询进行缓存,是减少数据库压力的主要途径。分为一级缓存和二级缓存
一级缓存:session级别缓存,作用于当前会话。
二级缓存:SessionFactory级别缓存,作用于整个SessionFactory,多个会话之间可以共享缓存
一级缓存默认开启(针对于同一次查询,方法和参数都相同的查询):
@Test
public void test1LevelCache() {
// 一次会话中
// 第1次查询
User user = userMapper.queryUserById(1L);
System.out.println(user);
System.out.println("------------------------------------------");
// 第2次查询
User user2 = userMapper.queryUserById(1L);
System.out.println(user2);
}
可以看到第二次查询没有访问数据库
一级缓存在执行了增删改操作后失效:
@Test
public void test1LevelCache() {
// 一次会话中
// 第1次查询
User user = userMapper.queryUserById(1L);
System.out.println(user);
// 测试增删改清空缓存
userMapper.deleteById(15L);
System.out.println("------------------------------------------");
// 第2次查询
User user2 = userMapper.queryUserById(1L);
System.out.println(user2);
}
可以看到在执行删除操作后再次查询,则会重新访问数据库
二级缓存:
特点:
- 二级缓存需要手动开启,开启的方式是在Mapper.xml中添加标签:<cache/>
- 二级缓存的作用域是整个SessionFactory,并且是同一个Mapper中,如果namespace、statement和SQL参数一致,则缓存命中
- 注意:开启二级缓存后,查询的对象需要实现序列化接口
缓存配置:
<cache
eviction="FIFO"
flushInterval="60000"
size="512"
readOnly="true"/>