• MyBatis中的一二级缓存


    MyBatis是一种持久化框架,它提供了一级和二级缓存来提高数据库访问性能。

    一级缓存是MyBatis默认开启的缓存机制,它是基于线程的缓存,每个SqlSession都有一个独立的一级缓存。当SqlSession执行查询操作时,查询结果会被存储在一级缓存中。当再次执行相同的查询时,MyBatis会先检查一级缓存中是否存在相同的查询结果,如果存在,则直接从缓存中获取查询结果,而不再去数据库中执行查询操作。一级缓存的生命周期是与SqlSession的生命周期相同,当SqlSession被关闭或提交事务时,一级缓存也会被清空。

    二级缓存是基于Mapper级别的缓存,它可以被多个SqlSession共享。当多个SqlSession执行相同的查询时,如果查询结果在二级缓存中存在,则所有的SqlSession都可以直接从缓存中获取查询结果,而不再去数据库中执行查询操作。二级缓存的生命周期是与应用程序的生命周期相同,当应用程序重新启动或重新部署时,二级缓存会被清空。

    要启用二级缓存,需要在MyBatis的配置文件中配置元素。可以配置以下属性来控制二级缓存的行为:

    • eviction:缓存的淘汰策略,默认为LRU(最近最少使用),还可以选择FIFO(先进先出)和SOFT(软引用)。
    • flushInterval:缓存刷新间隔时间,单位为毫秒,默认为不刷新。
    • readOnly:指定缓存是否只读,默认为false。
    • size:指定缓存的最大容量,默认为1024。

    需要注意的是,二级缓存只对查询操作有效,对于更新操作(insert、update、delete),MyBatis会自动清空相关的缓存。

    另外,对于一些特殊情况,可以使用@CacheNamespace注解来配置Mapper级别的缓存,或者使用@Cacheable和@CacheEvict注解来对特定的方法进行缓存配置。这些注解可以更加灵活地控制缓存的行为。

  • 相关阅读:
    【Node.JS】事件的绑定与触发
    UG\NX二次开发 获取所有子部件,封装两个函数
    关于安卓12闪屏页适配(一)
    mysql分区表的增删改查操作
    SpringBoot-37-RPC概述
    折线图的代码
    实战:实现一个LRU
    数据结构与算法3---栈与队
    GraphQL入门与开源的GraphQL引擎Hasura体验
    LeetCode刷题(6)
  • 原文地址:https://blog.csdn.net/weixin_54931655/article/details/133973717