mybatis的缓存
缓存就是为了提高查询的效率,从而提高性能
前言
学习目标:快速掌握mybatis缓存机制,希望可以帮助到你
提示:以下是本篇文章正文内容,下面案例可供参考
一、简介
1.什么是缓存?
- 存在内存中的临时数据
- 将用户经常查询的数据放在缓存(内存)中,用户去查询数据就不用从磁盘上(关系型数据库数据文件)查询,从缓存中查询,从而提高查询效率,解决了高并发系统的性能问题。
2.为什么使用缓存?
减少和数据库的交互次数,减少系统开销,提高系统效率
3.什么时候使用缓存?
- 经常查询并且不经常改变的数据适合使用缓存
- 反之,不经常查询且经常改变的数据不适合使用缓存
二、缓存分类
1.一级缓存
一级缓存是mybatis默认开启的缓存,我们不用自己去开启。它是SqlSession级别(一个sql语句中)的缓存也称为本地缓存,当调用SqlSession的修改,添加,删除,commit(),close(),clearCache()等方法时,就会清空一级缓存
一次查询的结果,给他暂存在缓存(内存)中,我们再去查询相同的数据时候就可以直接走缓存,就不用走数据库了。
代码如下(示例):
public class MyApp7 {
//测试查询
public static void main(String[] args) {
SqlSession sqlSession = MybatisUtils.getSqlSession();
StudentDao dao = sqlSession.getMapper(StudentDao.class);
Student student1 = dao.selectStudentById(1001);
System.out.println(student1);
Student student2 = dao.selectStudentById(1001);
System.out.println(student2);
System.out.println(student1==student2);
}
}
详细执行过程如下图:
对比代码如下(示例也就是当我们使用clearCache()清理缓存时再次运行main方法):
public class MyApp7 {
//测试查询
public static void main(String[] args) {
//MybatisUtils是工具类里面封装了获取SqlSession对象,保证使用统一SqlSession对象
SqlSession sqlSession = MybatisUtils.getSqlSession();
StudentDao dao = sqlSession.getMapper(StudentDao.class);
Student student1 = dao.selectStudentById(1001);
System.out.println(student1);
sqlSession.clearCache();//调用清理缓存的方法
Student student2 = dao.selectStudentById(1001);
System.out.println(student2);
System.out.println(student1==student2);
}
}
执行结果如下:
2.二级缓存
二级缓存是namespace级别(一个mapper映射文件)的缓存(也就是在同一个mapper下都会生效),需要我们手动开启和配置
注意:二级缓存只有在一级缓存死掉才可以执行
如何配置二级缓存?(主配置全文件可在主页mybtais文件夹中找到)
- 先在mybatis.xml(主配置文件)的settings标签中添加
<setting name="cacheEnabled" value="true"/>
- 在mapper.xml(sql映射文件中)的mapper标签中添加
<cache/>
标签
如何开启二级缓存?
在你想用二级缓存的语句标签中添加
useCache="true"
代码如下(示例):
<select id="selectStudentById" resultMap="StudentUserMap" parameterType="int" useCache="true">
select id,name,email,age from student where id = #{id}
</select>
public class MyApp7 {
//测试查询
public static void main(String[] args) {
SqlSession sqlSession1 = MybatisUtils.getSqlSession();
SqlSession sqlSession2 = MybatisUtils.getSqlSession();
StudentDao dao1 = sqlSession1.getMapper(StudentDao.class);
StudentDao dao2 = sqlSession2.getMapper(StudentDao.class);
Student student1 = dao1.selectStudentById(1001);
System.out.println(student1);
Student student2 = dao2.selectStudentById(1001);
System.out.println(student2);
System.out.println(student1==student2);
MybatisUtils.closeSqlSession();
}
}
执行结果如下:
代码如下(一级缓存关闭才会生效示例):
public class MyApp7 {
//测试查询
public static void main(String[] args) {
SqlSession sqlSession1 = MybatisUtils.getSqlSession();
SqlSession sqlSession2 = MybatisUtils.getSqlSession();
StudentDao dao1 = sqlSession1.getMapper(StudentDao.class);
StudentDao dao2 = sqlSession2.getMapper(StudentDao.class);
Student student1 = dao1.selectStudentById(1001);
System.out.println(student1);
sqlSession1.close();//关闭了一级缓存,并且把一级缓存中的数据丢到了二级缓存中
Student student2 = dao2.selectStudentById(1001);
System.out.println(student2);
System.out.println(student1==student2);
sqlSession2.close();
}
}
执行结果如下: