缓存
简介
什么是缓存?
- 存在内存中的临时数据
- 将用户经常查询的数据放在缓存中,用户查询数据就不用从磁盘上查询,从而提供查询效率,解决了高并发系统性的问题
为什么使用缓存?
- 减少和数据库的交互次数,减少系统开销,提供系统效率
什么样的数据能使用缓存?
- 经过查询并且不经常改变的数据
Mybatis缓存
-
MyBatis 内置了一个强大的事务性查询缓存机制,它可以非常方便地配置和定制。
-
默认情况下,只启用了本地的会话缓存,它仅仅对一个会话中的数据进行缓存。
-
要启用全局的二级缓存,只需要在你的 SQL 映射文件中添加一行:
<cache/>
一级缓存
- 一级缓存也叫本地缓存:Sqlsession
- 与数据库同一次会话期间查询到的数据会放在本地缓存中
- 以后如果获取相同数据,直接从缓存中获取,没有必要载去查询数据库
测试步骤
-
开启日志
<settings> <!-- 标准的日志工厂实现--> <setting name="logImpl" value="STDOUT_LOGGING"/> </settings>
-
测试在一个session中查询相同输出
public class UserMapperTest { @Test public void selectById(){ SqlSession sqlSession = MybatisUtils.getSqlSession(); UserMapper mapper = sqlSession.getMapper(UserMapper.class); User user = mapper.selectById(1); System.out.println(user); System.out.println("=================================================="); User user1 = mapper.selectById(1); System.out.println(user1); System.out.println(user == user1); sqlSession.close(); } }
-
查看日志
缓存失效的情况:
-
查询不同的对象
@Test public void selectById(){ SqlSession sqlSession = MybatisUtils.getSqlSession(); UserMapper mapper = sqlSession.getMapper(UserMapper.class); User user = mapper.selectById(1); System.out.println(user); System.out.println("=================================================="); User user1 = mapper.selectById(2); System.out.println(user1); System.out.println(user == user1); sqlSession.close(); }
-
增删除可能会改变原来的数据,所以必定会刷新缓存
public class UserMapperTest { @Test public void selectById(){ SqlSession sqlSession = MybatisUtils.getSqlSession(); UserMapper mapper = sqlSession.getMapper(UserMapper.class); User user = mapper.selectById(1); System.out.println(user); mapper.updateUser(new User(2, "张三", "111111")); System.out.println("=================================================="); User user1 = mapper.selectById(1); System.out.println(user1); System.out.println(user == user1); sqlSession.close(); } }
-
查询不同的mapper.xml
-
手动清理缓存
public class UserMapperTest { @Test public void selectById(){ SqlSession sqlSession = MybatisUtils.getSqlSession(); UserMapper mapper = sqlSession.getMapper(UserMapper.class); User user = mapper.selectById(1); System.out.println(user); sqlSession.clearCache();//手动清理缓存 System.out.println("=================================================="); User user1 = mapper.selectById(1); System.out.println(user1); System.out.println(user == user1); sqlSession.close(); } }
小结:
-
一级缓存默认开启,只在一次sqlsession中有效,即连接到关闭。
-
一级缓存就是一个Map
上一节—>动态sql
如有不对的地方欢迎指出,共同进步!