概念和使用场景
- 缓存的概念:存在于内存中的临时数据。
- 为什么使用缓存:减少和数据库的交互次数,提高执行效率。
- 适用于缓存的数据:经常查询并且不经常改变的,数据的正确与否对最终结果影响不大的。
- 不适用于缓存的数据:经常改变的,数据的正确与否对最终结果影响很大的。
一级缓存
一级缓存指的是Mybatis中SqlSession对象的缓存。
当执行查询之后,查询的结果会同时存入到SqlSession提供一块区域中。
该区域的结构是一个Map。当再次查询同样的数据,Mybatis会先去sqlsession中
查询是否有该数据,有的话直接使用不再访问数据库。
当SqlSession对象销毁时,Mybatis的一级缓存随之销毁。
测试一级缓存
@Test
public void testFirstLevelCatch() {
User user1 = userDao.findById(41);
System.out.println(user1);
User user2 = userDao.findById(41);
System.out.println(user2);
System.out.println(user1 == user2);
}
测试结果
测试SqlSession对象销毁时一级缓存是否销毁
@Test
public void testFirstLevelCatch() {
User user1 = userDao.findById(41);
System.out.println(user1);
sqlSession.close();
sqlSession= factory.openSession();
userDao = sqlSession.getMapper(IUserDao.class);
User user2 = userDao.findById(41);
System.out.println(user2);
System.out.println(user1 == user2);
}
测试结果
注意事项:
- clearCache()方法也可以清空一级缓存。
- 当调用SqlSession的修改,添加,删除,commit(),close()等方法时会清空一级缓存。
二级缓存:
二级缓存指的是Mybatis中SqlSessionFactory对象的缓存。由同一个SqlSessionFactory对象创建的SqlSession共享其缓存。
二级缓存的使用步骤:
- 第一步:让Mybatis框架支持二级缓存,在主配置文件中配置。
<settings>
<setting name="cacheEnabled" value="true"></setting>
</settings>
- 第二步:让当前的映射文件支持二级缓存。
<cache></cache>
- 第三步:让当前的操作支持二级缓存,在标签中配置。
<select id="findById" parameterType="INT" resultType="user" useCache="true">
select * from user where id = #{uid}
</select>
测试代码
@Test
public void testFirstLevelCatch() {
SqlSession sqlSession1 = factory.openSession();
IUserDao dao1 = sqlSession1.getMapper(IUserDao.class);
User user1 = dao1.findById(41);
System.out.println(user1);
sqlSession1.close();
SqlSession sqlSession2 = factory.openSession();
IUserDao dao2 = sqlSession2.getMapper(IUserDao.class);
User user2 = dao2.findById(41);
System.out.println(user2);
sqlSession1.close();
System.out.println(user1 == user2);
}