MyBatis 缓存机制详解

引言

在高并发系统中,数据库查询往往是性能瓶颈之一。为了提高查询效率,减少数据库的访问次数,缓存机制应运而生。MyBatis作为一款优秀的ORM框架,内置了强大的查询缓存特性,支持一级缓存和二级缓存两种缓存机制。

拓展阅读深入理解 MyBatis 框架的核心对象:SqlSession


一、缓存的作用与分类

缓存(Cache) 是一种临时存储数据的机制,用于加速重复数据的访问。MyBatis 提供两级缓存

  • 一级缓存:默认开启,基于 SqlSession 生命周期。在同一个SqlSession中执行相同的查询语句时,MyBatis会先查看一级缓存中是否存在之前查询的结果,如果存在则直接从缓存中读取数据,而不会再次发送数据库请求。
  • 二级缓存:需手动开启,基于 Mapper 命名空间,跨会话共享。同一个mapper的多个SqlSession共享二级缓存。二级缓存需要显式开启和配置。

二、一级缓存:会话级缓存
1. 核心特性
  • 作用范围:同一个 SqlSession 内的查询结果会被缓存。
  • 自动生效:执行相同的 SQL 和参数时,直接从内存返回结果。
  • 生命周期:随 SqlSession 的创建而开启,随其关闭或清空而销毁。
2. 缓存失效场景
  • 执行 insertupdatedelete 操作(任何写操作)。
  • 调用 sqlSession.clearCache() 手动清空。
  • 配置 flushCache="true"(如 <select flushCache="true">)。
3. 示例与验证
// 通过SqlSessionFactory创建一个SqlSession对象
// Sql
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值