Mybatis缓存机制

系列文章目录

1、mybatis简介及数据库连接池

2、mybatis简单使用

3、mybatis中selectOne的使用

4、mybatis中resultMap结果集的使用

5、mybatis实用教程之XML实现动态sql

6、Mybatis使用注解实现复杂动态SQL


Mybatis缓存机制


前言

MyBatis 提供了两级缓存机制:一级缓存(本地缓存)和二级缓存(全局缓存)。一级缓存是默认开启的,它是基于 SqlSession 级别的缓存,同一个 SqlSession 内相同的查询会被缓存起来;二级缓存是跨 SqlSession 的缓存,它可以被多个 SqlSession 共享,需要在 Mapper 文件中显式配置启用。

一级缓存对于减少数据库访问,提高性能有一定帮助,但是仅限于同一个 SqlSession 内。而二级缓存则是跨 SqlSession 的,可以跨 Session 共享缓存结果,适用于跨 Session 但是相同查询的情景。


1、配置二级缓存

  1. 在 MyBatis 的配置文件中开启二级缓存:
xml 复制代码
<configuration>
    <settings>
        <setting name="cacheEnabled" value="true"/>
    </settings>
</configuration>
  1. 在需要使用二级缓存的 Mapper 文件中添加 <cache> 标签:
xml 复制代码
<mapper namespace="com.example.mapper.UserMapper">
    <cache/>
    <!-- 其他 SQL 映射配置 -->
</mapper>

2、使用场景:

假设有一个用户信息查询的场景,多个不同的用户查询请求频繁访问相同的数据。

java 复制代码
// UserMapper.java
public interface UserMapper {
    List<User> getAllUsers();
}
xml 复制代码
<!-- UserMapper.xml -->
<mapper namespace="com.example.mapper.UserMapper">
    <cache/>
    <select id="getAllUsers" resultType="User">
        SELECT * FROM users
    </select>
</mapper>
java 复制代码
// 使用代码
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(Resources.getResourceAsReader("mybatis-config.xml"));
try (SqlSession sqlSession = factory.openSession()) {
    UserMapper userMapper = sqlSession.getMapper(UserMapper.class);

    // 第一次查询
    List<User> users1 = userMapper.getAllUsers();
    // 再次查询相同数据
    List<User> users2 = userMapper.getAllUsers();
}

3、注意事项:

  • 缓存的命中和失效机制:如果数据库中数据被修改,会导致对应的缓存失效,需要注意缓存的更新策略。
  • 需要小心缓存带来的数据一致性问题,在某些情况下需要手动清除缓存以保证数据的最新性。

这个示例展示了 MyBatis 的二级缓存配置和使用场景,但在实际应用中,需要根据业务情况和性能调优来决定是否使用缓存,并针对具体情况进行调整。

相关推荐
JAVA面经实录9171 分钟前
操作系统面试题
java·服务器·数据库·计算机网络·面试
一杯奶茶¥42 分钟前
基于springboot的失物招领管理系统带万字文档 校园失物招领管理系统 失物认领管理系统java springboot vue
java·vue.js·spring boot·java项目
不能只会打代码1 小时前
边缘视频分析平台的架构设计与性能优化——从750ms到190ms的调优之路
java·spring boot·redis·性能优化·边缘计算·物联网竞赛
小刘|1 小时前
Spring AI Alibaba 集成和风天气 API 实战
java·服务器·前端
KANGBboy1 小时前
java知识五(继承)
java·开发语言
AI人工智能+电脑小能手1 小时前
【大白话说Java面试题 第117题】【并发篇】第17题:线程有几种状态,之间如何转换?
java·开发语言·面试
DIY源码阁1 小时前
JavaSwing饮品管理系统 - MySQL版
java·数据库·mysql·eclipse
二哈赛车手1 小时前
新人笔记---最终版智能体图片分析完整方案,包括一些总结于经验,以及各种优化点讲解
java·笔记·spring·ai·springboot
泡^泡2 小时前
Spring AI简单高仿DeepSeek问答页面
java·人工智能·spring
带刺的坐椅2 小时前
Solon v4.0 正式发布,高考记忆版
java·ai·solon·flow·solon-ai