MyBatis的缓存

Mybatis的一级缓存

一级缓存是++sqlSession++级别的,通过同一个SqlSession查询的数据会被缓存,下次查询相同的数据,就会从缓存中直接获取,不会从数据库重新访问

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

  1. 不同的SqlSession对应不同的一级缓存
  2. 同一个SqlSession但是查询条件不同
  3. 同一个SqlSession两次查询期间执行了任何一次增删改操作
  4. 同一个SqlSession两次查询期间手动清空了缓存
java 复制代码
SqlSession session = sqlSessionFactory.openSession();

// 第一次查询,缓存为空
User user1 = session.selectOne("com.example.UserMapper.selectUserById", 1);

// 第二次查询,缓存命中
User user2 = session.selectOne("com.example.UserMapper.selectUserById", 1);

// 此时 user1 和 user2 引用的是相同的对象,因为一级缓存命中
assert user1 == user2;

session.close();  // 关闭后一级缓存失效

Mybatis的二级缓存

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

二级缓存开启的条件:

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

使二级缓存失效的情况:

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

全局配置

XML 复制代码
<configuration>
    <!-- 启用二级缓存 -->
    <settings>
        <setting name="cacheEnabled" value="true"/>
    </settings>
</configuration>

mapper配置

XML 复制代码
<mapper namespace="com.example.UserMapper">
    <!-- 启用二级缓存 -->
    <cache/>
    
    <!-- SQL 映射 -->
    <select id="selectUserById" resultType="User">
        SELECT * FROM users WHERE id = #{id}
    </select>
</mapper>

总结

一级缓存 :作用于同一个 SqlSession,默认启用,简单有效。

二级缓存 :作用于整个 Mapper,跨 SqlSession 共享缓存,需要手动启用。

缓存的优势:减少数据库访问次数,提升查询效率。

缓存的使用:合理配置缓存策略,确保数据的一致性和及时更新。

相关推荐
2301_771717212 分钟前
Java自定义注解创建详解
java·开发语言
艾莉丝努力练剑8 分钟前
【Linux系统:信号】线程安全不等于可重入:深度拆解变量作用域与原子操作
java·linux·运维·服务器·开发语言·c++·学习
无心水9 分钟前
20、Spring陷阱:Feign AOP切面为何失效?配置优先级如何“劫持”你的设置?
java·开发语言·后端·python·spring·java.time·java时间处理
QfC92C02p9 分钟前
C# 中的 Span 和内存:.NET 中的高性能内存处理
java·c#·.net
0xDevNull14 分钟前
Java 21 新特性概览与实战教程
java·开发语言·后端
柏林以东_20 分钟前
java遍历的所有方法及优缺点
java·开发语言·数据结构
升职佳兴25 分钟前
SQL 进阶3:连续登录问题与 ROW_NUMBER 差值法完整解析
java·数据库·sql
KhalilRuan33 分钟前
Burst编译器的底层原理
java·开发语言
Zww089144 分钟前
idea配置注释模板
java·ide·intellij-idea
Renhao-Wan1 小时前
Docker 核心原理详解:镜像、容器、Namespace、Cgroups 与 UnionFS
java·后端·docker·容器