mybatis中的缓存

 缓存的概念:

  • 存储在内存当中的数据
  • 将用户常使用的数据存放在缓存(内存)当中,用户查询数据就不用从磁盘(关系型数据库文件)当中查询,从缓存当中查询,从而提高查询效率,解决了高并发系统的性能问题
  • 减少和数据库的交互次数,减少系统开销,提高系统效率
  • 经常查询并且不常改变的数据

mybatis系统当中默认定义了两级缓存:一级缓存和二级缓存

1)一级缓存:

  • sqlSession级别的
  • 存在于 sqlSession的生命周期中。
  • sqlSession.commit()之后,会重新发送SQL进行查询,即缓存消失
  • 查询相同数据,在不commit和close的前提下,只会发送一次SQL,后面的都通过前者查出的数据来直接使用,提高了效率
  • 缓存失效的几种情况:
    • sqlSession不同
    • sqlSession相同,查询条件不同
    • sqlSession相同,两次查询之间执行了增删改操作!
    • sqlSession相同,手动清除一级缓存

 没写commit,查询相同数据,只发送了一次SQL,炒同样的菜,没必要洗锅了

 加上commit,发送了两次SQL

 

2)二级缓存 

  • 工厂级别的 :namespace级别
  • 存在于 SqlSessionFactory 的生命周期中。
  •  在UserMapper.xml配置文件声明使用二级缓存

  • <!--使用二级缓存-->
    
    <cache eviction="FIFO" #收回策略
    
            flushInterval="6000" #刷新间隔
    
            size="512" #引用数目
    
            readOnly="true"/> #只读
  •  在mybatis-config.xml配置文件中开启二级缓存,默认为true,开启
  • <!‐‐ 开启二级缓存 ‐‐>
    <settings>
        <!--开启二级缓存-->
        <setting name="cacheEnabled" value="true"/>
    </settings>
  •  有可能会报类未序列化的错误,此时你需要去让类实现Serializable接口 

 

 

  • 二级缓存,只要工厂没有关闭,通过这个工厂得到的sqlSession,都会存在缓存

        下面这张图你会发现,我们通过工厂得到了两个sqlSession,但是由于工厂并没有关闭

        二级缓存的存在让我们在查询相同数据,或者说调用同一个方法时,只发送了一次SQL

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值