mybatis的缓存,看这一篇就够了!

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文件夹中找到)

  1. 先在mybatis.xml(主配置文件)的settings标签中添加<setting name="cacheEnabled" value="true"/>
  2. 在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();
    }
}

执行结果如下:
在这里插入图片描述

总结

内容很长,有不足和错误地方,欢迎指导,我会及时更改,谢谢观看! 当然以后工作会用Redis数据库来做缓存,有兴趣的可以进一步去了解。
  • 11
    点赞
  • 40
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值