七、Mybatis-缓存

文章目录

缓存

一级缓存

级别为sqlSession,Mybatis默认开启一级缓存。

使一级缓存失效的四种情况:

  • 不同的SqlSession对应不同的一级缓存

  • 同一个SqlSession但是查询条件不同

  • 同一个SqlSession两次查询期间执行了任何一次增删改操作

  • 同一个SqlSession两次查询期间手动清空了缓存

二级缓存

1.概念

二级缓存是SalSessionFactory级别,通过同一个SqlSessionfactory创建的SqlSession查询的结果会被缓存;此后若再次执行相同的查询语句,结果就会从缓存中获取

2.二级缓存开启的条件:

  • 在核心配置文件中,设置全局配置属性cacheEnafled="true",默认为true,不需要设置
  • 在映射文件中设置标签< cache />
  • 二级缓存必须在SqlSession关闭或提交之后有效
  • 查询的数据所转换的实体类类型必须实现序列化的接口

3.使二级缓存失效的情况:

两次查询之间执行了任意的增删改,会使一级和二级缓存同时失效

4.在mapper配置文件中添加的cache标签可以设置一些属性:

  • eviction属性:缓存回收策略
    LRUlLeast Recently Used)-最近最少使用的:移除最长时间不被使用的对象。
    FIFO(First in First out)-先进先出:按对象进入缓存的顺序来移除它们。
    SOFT-软引用:移除基于垃圾回收器状态和软引用规则的对象。
    WEAK-弱引用:更积极地移除基于垃圾收集器状态和弱引用规则的对象。
    默认的是 LRU。
  • flushInterval属性:刷新间隔,单位毫秒默认情况是不设置,也就是没有刷新间隔,缓存仅仅调用语句时刷新
  • size属性:引用数目,正整数 代表缓存最多可以存储多少个对象,太大容易导致内存溢出
  • readOnly属性:只读,true/false
    true:只读缓存;会给所有调用者返回缓存对象的相同实例。因此这些对象不能被修改。这提供了很重要的性能优势。
    false:读写缓存;会返回缓存对象的拷贝(通过序列化)。这会慢一些,但是安全,因此默认是 false。

5.MyBatis缓存查询的顺序

  1. 先查询二级缓存,因为二级缓存中可能会有其他程序已经查出来的数据,可以拿来直接使用。
  2. 如果二级缓存没有命中,再查询一级缓存。如果一级缓存也没有命中,则查询数据库
  3. SqlSession关闭之后,一级缓存中的数据会写入二级缓存
相关推荐
花花鱼18 小时前
Spring Security 与 Spring MVC
java·spring·mvc
言慢行善19 小时前
sqlserver模糊查询问题
java·数据库·sqlserver
专吃海绵宝宝菠萝屋的派大星19 小时前
使用Dify对接自己开发的mcp
java·服务器·前端
大数据新鸟19 小时前
操作系统之虚拟内存
java·服务器·网络
Tong Z19 小时前
常见的限流算法和实现原理
java·开发语言
凭君语未可19 小时前
Java 中的实现类是什么
java·开发语言
He少年19 小时前
【基础知识、Skill、Rules和MCP案例介绍】
java·前端·python
克里斯蒂亚诺更新20 小时前
myeclipse的pojie
java·ide·myeclipse
迷藏49420 小时前
**eBPF实战进阶:从零构建网络流量监控与过滤系统**在现代云原生架构中,**网络可观测性**和**安全隔离**已成为
java·网络·python·云原生·架构
迷藏49420 小时前
**发散创新:基于Solid协议的Web3.0去中心化身份认证系统实战解析**在Web3.
java·python·web3·去中心化·区块链