缓存
介绍
Mybatis包含一个非常强大的查询缓存特性,它可以非常方便地配置和定制。缓存可以极大的提升查询效率。
在Mybatis中定义了两级缓存:一级缓存和二级缓存。
默认情况下,只有一级缓存(SqlSession级别的缓存,也称为本地缓存)开启。
二级缓存需要手动开启和配置,他是基于namespace级别的缓存。
此外,为了提高扩展性。MyBatis定义了缓存接口Cache。我们可以通过实现Cache接口来自定义二级缓存。
一级缓存(本地缓存)
与数据库同一次会话期间查询到的数据会存放在本地缓存中,如果后续需要获取相同的数据,可以直接从缓存中拿,没必要再去查询数据库。
测试:
@Test
public void test12() throws IOException{
// 测试一级缓存
SqlSessionFactory sqlSessionFactory = getSqlSessionFactory();
SqlSession sqlSession = sqlSessionFactory.openSession();
try {
EmployeeMapper mapper = sqlSession.getMapper(EmployeeMapper.class);
Employee employee1 = mapper.getEmployeeById(1);
System.out.println(employee1);
Employee employee2 = mapper.getEmployeeById(1);
System.out.println(employee2);
System.out.print("employee1 == employee2 ? ");
System.out.println(employee1 == employee2);
} finally {
sqlSession.commit();
}
}
结果:
一级缓存失效的四种情况
前面说到一级缓存是SqlSession级别的缓存,那么就说明每个SqlSession都有自己的一级缓存,那么在遇到如下情况时一级缓存就会失效:
SqlSession不同
我们使用创建两个SqlSession对象来执行相同的查询:
@Test
public void test12() throws IOException{
// 测试一级缓存
SqlSessionFactory sqlSessionFactory = getSqlSessionFactory();
SqlSession sqlSession1 = sqlSessionFactory.openSession();
SqlSession sqlSession2 = sqlSessionFactory.openSession();
try {
EmployeeMapper mapper1 = sqlSession1.getMapper(EmployeeMapper<