mybatis中的缓存

发布于:2023-01-05 ⋅ 阅读:(309) ⋅ 点赞:(0)

 缓存的概念:

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

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

 


网站公告

今日签到

点亮在社区的每一天
去签到