简介
当我们执行查询操作时,需要连接数据库,是一个十分耗资源的操作,如果我们将一次查询的结果放入缓存中,那么下一次再查该数据时就可以直接取缓存里面取,节省资源。
什么是缓存(cache)
①:存放在内存中的临时数据
②:我们将用户经常查询的数据放在缓存(内存)中,用户查询数据就不用再从磁盘上取,而是从缓存中取,可以提高查询效率,解决高并发系统的性能问题
为什么使用缓存
减少和数据库的交互次数,减少系统开销,提高系统效率
什么样的数据使用缓存
经常查询并且不经常改变的数据
MyBatis缓存
MyBatis包含一个非常强大的查询缓存特性,它可以很方便地定制和配置缓存,缓存可以极大的提升查询效率
MyBatis 默认定义了两级缓存:一级缓存 和 二级缓存。默认情况下只有一级缓存开启(SqlSession 级别的缓存,也称为本地缓存)。二级缓存是 namespace 级别的缓存,需要手动开启和配置,我们可以使用 Cache 接口来自定义二级缓存。
一级缓存
使用 User 表
我们在一次测试中来两次获取相同的用户
@Test
public void test1(){
SqlSession sqlSession = MyBatisUtils.getSqlSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
User user = mapper.getUser(1);