Mybatis笔记13(完结)--缓存

13、缓存

查询:要连接数据库---耗资源
优化:把一次查询的结果,给暂存一个可以直接取到的地方!-->内存:缓存
当我们再次查询相同的数据时,直接走缓存,就不用走数据库了

1、简介

  1. 什么是缓存[Cache]?

    • 存在内存中的临时数据
    • 将用户经常查询的数据放在缓存(内存)中,用户去查询数据就不用从磁盘上(关系型数据数据文件)查询,从缓存中查询,从而提高查询效率,解决了高并发系统的性能问题。
  2. 为什么使用缓存?

    • 减少和数据库的交互次数,减少系统开销,提高系统效率
  3. 什么样的数据能使用缓存?

    • 经常查询并且不经常改变的数据。

2、Mybatis缓存

  • Mybatis包含一个非常强大的查询缓存特性,它可以非常方便地定制和配置缓存。缓存可以极大的提升查询效率
  • Mybatis系统中默认定义两级缓存:一级缓存二级缓存
    • 默认情况下,只有一级缓存开启。(SqlSession级别的缓存,也称为本地缓存)
    • 二级缓存需要手动开启和配置,他是基于namespace级别的缓存。、
    • 为了提高扩张性,Mybatis定义了缓存接口Cache。我们可以通过实现Cache接口来定义二级缓存

3、一级缓存

  • 一级缓存也叫本地缓存:
    • 与数据库同一次会话期间会查询到的数据放在本地缓存中
    • 以后如果需要获取相同的数据,直接从缓存中拿,没必要再去查询数据库;

测试步骤:

  1. 开启日志!配置文件中配置

        <settings>
            <!--标准的日志工厂实现-->
            <setting name="logImpl" value="STDOUT_LOGGING"/>
            <!--名字必须和官网一样,不能有有空格-->
        </settings>
    

    2.测试在一个Sesion中查询两次相同的记录

    3.查看日志输出

        @Test
        public void getUserById(){
         
            SqlSession sqlSession = MybatisUtils.getSqlSession();
            UserMapper mapper = sqlSession.getMapper(UserMapper.class);
            User user1 = mapper.getUserById(1);
            System.out.println(user1);
            System.out.println("===================================");
            User user2 = mapper.getUserById(1);
            System.out
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值