MyBatis(39)如何在 MyBatis 中实现查询缓存的更新和失效策略

要深入理解MyBatis中查询缓存的更新和失效策略,首先需要明白MyBatis提供了两级缓存:一级缓存(Session级别)和二级缓存(Mapper级别)。接下来,我们将分别讨论这两种缓存的实现机制,以及如何通过源码层面控制缓存的更新和失效策略。

一级缓存(Session缓存)

一级缓存是默认开启的,它基于SqlSession的生命周期。在同一个SqlSession中进行的查询会被缓存,当再次执行相同的查询时,MyBatis会直接从缓存中获取结果,而不是访问数据库。

失效策略

  1. SqlSession关闭或清除:当调用SqlSession.close()方法或SqlSession.clearCache()时,一级缓存会被清空。
  2. 执行更新操作:当在一个SqlSession中执行任何INSERTUPDATEDELETE操作后,MyBatis会清空该SqlSession的缓存,以确保数据的一致性。

二级缓存(Mapper缓存)

二级缓存是跨SqlSession的,它基于Mapper的namespace级别。要启用二级缓存,需要在MyBatis配置文件中以及Mapper的XML文件中进行配置。

开启方法

  1. mybatis-config.xml全局配置文件中启用二级缓存:
<configuration>
    <settings>
        <setting name="cacheEnabled" value="true"/>
    </settings>
</configuration>
  1. 在Mapper的XML文件中添加<cache/>标签开启二级缓存:
<mapper namespace="org.mybatis.example.UserMapper">
    <cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>
</mapper>

失效策略

  • 自动失效:二级缓存会根据其eviction属性(缓存回收策略)、flushInterval(刷新间隔)、size(引用数量)等配置自动进行管理和失效。
  • 手动触发失效:执行INSERTUPDATEDELETE操作时,如果这些操作可能影响到缓存中的数据,MyBatis会清空相关Mapper的二级缓存。

源码解析

MyBatis缓存管理主要涉及Cache接口及其实现类,例如PerpetualCache是一个简单的永久缓存,使用HashMap存储缓存项。CacheKey类用于生成缓存项的键,考虑到查询语句、参数、分页信息等因素。

更新和失效逻辑

CachingExecutor类为例,它是执行CUD(创建、更新、删除)操作和查询操作时对缓存进行管理的关键。

  • 对于CUD操作,CachingExecutor会调用update()方法,在执行完数据库操作后,会调用clearLocalCache()清除一级缓存。此外,如果配置了二级缓存,还会调用tCache.clear()清除相关Mapper的二级缓存。

  • 对于查询操作,首先会尝试从一级缓存中获取结果。如果一级缓存未命中,再尝试从二级缓存中获取。如果两级缓存都未命中,则执行数据库查询,并将查询结果缓存到一级缓存和二级缓存中。

代码演示

假设有一个简单的更新操作,我们如何控制缓存的失效:

public interface UserMapper {
    User findUserById(Integer id);
    void updateUser(User user);
}

UserMapper.xml中配置二级缓存,并声明更新操作:

<mapper namespace="com.example.mapper.UserMapper">
    <cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>

    <select id="findUserById" resultType="User">
        SELECT * FROM user WHERE id = #{id}
    </select>
    
    <update id="updateUser">
        UPDATE user SET name = #{name}, email = #{email} WHERE id = #{id}
    </update>
</mapper>

在这个例子中,每当updateUser方法被调用后,MyBatis会自动清除UserMapper对应的二级缓存。这确保了之后的查询能反映最新的数据状态。

总结

通过深入分析MyBatis的缓存机制,我们了解到一级缓存和二级缓存的工作原理及其失效策略。合理配置和使用这些缓存策略,可以显著提升应用性能。了解和掌握源码层面的缓存管理逻辑,对于设计高效、可维护的缓存策略尤为重要。

相关推荐

  1. MyBatis35如何 MyBatis 实现软删除

    2024-07-13 10:00:03       24 阅读
  2. MyBatis-Plus ,字段更新为 null 方法

    2024-07-13 10:00:03       17 阅读
  3. MyBatis可以如何实现分页查询

    2024-07-13 10:00:03       27 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-13 10:00:03       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-13 10:00:03       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-13 10:00:03       58 阅读
  4. Python语言-面向对象

    2024-07-13 10:00:03       69 阅读

热门阅读

  1. Vue.js Ajax(axios)

    2024-07-13 10:00:03       20 阅读
  2. 开源项目有哪些机遇与挑战?

    2024-07-13 10:00:03       20 阅读
  3. Spring Boot集成Atomix快速入门Demo

    2024-07-13 10:00:03       24 阅读
  4. Python实现网站IP地址查询

    2024-07-13 10:00:03       20 阅读
  5. parquet-go的CSVWriter

    2024-07-13 10:00:03       27 阅读
  6. 玩转鸿蒙NXET之组件导航与路由跳转二

    2024-07-13 10:00:03       23 阅读
  7. Go语言入门之数组切片

    2024-07-13 10:00:03       28 阅读
  8. P6. 对局列表和排行榜功能

    2024-07-13 10:00:03       24 阅读
  9. 使用Nginx实现高效负载均衡

    2024-07-13 10:00:03       23 阅读
  10. CRC32简述

    2024-07-13 10:00:03       25 阅读
  11. 赛博灯泡3.0,未完善,无bug

    2024-07-13 10:00:03       21 阅读
  12. C#——二进制流序列化和反序列化

    2024-07-13 10:00:03       28 阅读