MyBatis 缓存机制

本是古典 何须时尚 2023-09-23 16:06 5阅读 0赞

文章目录

    • 一、一级缓存
    • 二、二级缓存
      • 1.cache 元素
      • 2.缓存命中率

一、一级缓存

MyBatis 的一级缓存是 SqlSession 级别的缓存。如果同一个 SqlSession 对象多次执行完全相同的 SQL 语句,在第一次执行完成后,MyBatis 会将查询结果写入一级缓存中,此后,如果程序没有执行插入、更新和删除操作,当第二次再执行相同的查询语句时,MyBatis 会直接读取一级缓存中的数据,而不用再去数据库查询,从而提高了数据库的查询效率。

在这里插入图片描述

那么我们怎么知道第二次它没有操作数据库呢?
可以通过日志组件来查看一级缓存的工作状态,因此第一步需要在 pom.xml 中引入日志依赖。

  1. <dependency>
  2. <groupId>log4j</groupId>
  3. <artifactId>log4j</artifactId>
  4. <version>1.2.17</version>
  5. </dependency>

第二步在 resources 目录下创建 log4j.properties 文件,注意文件名必须只能是 log4j.properties。

  1. #全局日志配置
  2. log4j.rootLogger=DEBUG,Console
  3. #控制台输出配置
  4. log4j.appender.Console=org.apache.log4j.ConsoleAppender
  5. log4j.appender.Console.layout=org.apache.log4j.PatternLayout
  6. log4j.appender.Console.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n
  7. #日志输出级别,只展示了一个
  8. log4j.logger.java.sql.PreparedStatement=DEBUG

增删改会导致一级缓存的清空!

二、二级缓存

相同的 Mapper 类,相同的 SQL 语句,如果 SqlSession 不同,则两个 SqlSession 查询数据库时,会查询数据库两次,这样也会降低数据库的查询效率。为了解决这个问题,就需要用到 MyBatis 的二级缓存。MyBatis 的二级缓存是 Mapper 级别的缓存,与一级缓存相比,二级缓存的范围更大,多个 SqlSession 可以共用二级缓存,并且二级缓存可以自定义缓存资源。
在 MyBatis 中,一个 Mapper.xml 文件通常称为一个 Mapper,MyBatis 以 namespace 区分 Mapper,如果多个 SqlSession 对象使用同一个 Mapper 的相同查询语句去操作数据库,在第一个 SqlSession 对象执行完后,MyBatis 会将查询结果写入二级缓存,此后,如果程序没有执行插入、更新、删除操作,当第二个 SqlSession 对象执行相同的查询语句时,MyBatis 会直接读取二级缓存中的数据。

在这里插入图片描述
同样,增删改查操作会清空二级缓存!

1.cache 元素

与 MyBatis 的一级缓存不同的是,MyBatis 的二级缓存需要手动开启,开启二级缓存通常要完成以下两个步骤:
① 在 MyBatis 的核心配置文件 MybatisConfig.xml 文件中通过 settings 元素开启二级缓存的全局配置;

  1. <settings>
  2. <setting name="cacheEnabled" value="true" />
  3. </settings>

② 开启当前 Mapper 的 namespace 下的二级缓存,可以通过 MyBatis 映射文件中的 cache 元素来完成。

  1. <!-- 开启当前Mapper的namespace下的二级缓存 -->
  2. <cache>
  3. </cache>

默认状态下的二级缓存可实现的功能:
① 映射文件中所有的 select 语句将会被缓存;
② 映射文件中的所有 insert、update 和 delete 语句都会刷新缓存;
③ 缓存会使用 LRU 算法回收;
④ 没有刷新间隔,缓存不会以任何时间顺序来刷新;
⑤ 缓存会存储列表集合或对象的1024个引用;
⑥ 缓存是可读/可写的缓存,这意味着对象检索不是共享的,缓存可以安全的被调用者修改,而不干扰其他调用者或线程所做的潜在修改。

以上是二级缓存在默认状态下的特性,如果需要调整上述特性,可以通过 cache 元素的属性来实现。

在这里插入图片描述

其中,eviction 属性有四个可选值:
① LRU,最近最少使用的策略,移除最长时间不被使用的对象;
② FIFO,先进先出策略,按对象进入缓存的顺序来移除它们;
③ SOFT,软引用策略,移除基于垃圾回收器状态和软引用规则的对象;
④ WEAK,弱引用策略,更积极地移除基于垃圾收集器状态和弱引用规则的对象。

在第一次查询结束时释放 SqlSession,将数据写入二级缓存,session1.close()!

2.缓存命中率

终端用户访问存储时,如果在缓存中查找到了要被访问的数据,就叫做命中。当多次执行查询操作时,缓存命中次数与总的查询次数(缓存命中次数+缓存没有命中次数)的比,就叫做缓存命中率,即缓存命中率=缓存命中次数/总的查询次数。当 MyBatis 开启二级缓存后,第一次查询数据时,由于数据还没有进入缓存,所以需要在数据库中查询而不是在缓存中查询,此时缓存命中率为0,第一次查询过后,MyBatis 会将查询到的数据写入缓存中,当第二次再查询相同的数据时,MyBatis会直接从缓存中获取这条数据,缓存将命中,此时的缓存命中率为0.5,当第三次查询相同的数据,则缓存命中率为0.6666,以此类推。

发表评论

表情:
评论列表 (有 0 条评论,5人围观)

还没有评论,来说两句吧...

相关阅读

    相关 mybatis缓存机制

    一.MyBatis 缓存详解   缓存是一般的ORM 框架都会提供的功能,目的就是提升查询的效率和减少数据库的压力。跟Hibernate 一样,MyBatis 也有一级缓存

    相关 Mybatis缓存机制

    Mybatis系统中默认定义了两级缓存。 一级缓存和二级缓存 1、默认情况下只有一级缓存(SqlSession级别的缓存,也称为本地缓存)开启 2、二级缓存需要手动

    相关 Mybatis缓存机制

    概述         mybatis的缓存分为一级缓存和二级缓存。         一级缓存是会话级别,也就是session级别。一级缓存默认开启,用户不能手动配置(但

    相关 MyBatis 缓存机制

         在实际项目开发中,通常对数据库查询的性能要求很高,而MyBatis提供了查询缓存来缓存数据,从而达到提高查询性能的要求。MyBatis的查询缓存分为一级缓存(sqlS

    相关 Mybatis 缓存机制

    缓存 查询缓存主要是为了提高查询访问速度,即当用户执行一次查询后,会将该数据结果放到缓存中,当下次再执行此查询时就不会访问数据库了而是直接从缓存中获取该数据。 如果在缓存

    相关 mybatis缓存机制

     1、一级缓存 MyBatis 包含一个非常强大的查询缓存特性,使用缓存可以使应用更快地获取数据,避免频繁的数据库交互 ;  一级缓存默认会启用,想要关闭一级缓存

    相关 MyBatis缓存机制

    MyBatis的前身是iBATIS,它是一款优秀的支持自定义SQL查询、存储过程和高级映射的持久层框架,消除了几乎所有的JDBC代码和参数的手动设置以及结果集的检索。在日常工作