• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

SpringBoot整合Mybatis开启本地二级缓存和使用redis开启二级缓存

武飞扬头像
境里婆娑
帮助2

目录

一、Mybatis缓存

二、mybatis开启本地二级缓存

1、在配置文件中添加以下代码

2、在需要开启的mapper.xml中,添加以下代码(在下方)

3、 mapper查询参数配置

4、启动应用发送查询请求

三、使用redis开启二级缓存

1、在上面基础架构搭建好之后,加上redis maven配置

2、在配置文件中加上redis配置

3、因为这个类不是Spring管理的,所以通过MyBatisRedisSpringContext从ioc容器里获取redisTemplate类

 4、mapper文件配置

 5、启动应用发送请求


一、Mybatis缓存

mybatis中有一级缓存和二级缓存,我们常用的是一级缓存,mybatis会默认打开。

  • 一级缓存

一级缓存是SqlSession级别。一级缓存的作用域是 SqlSession , Mabits 默认开启一级缓存。 在同一个SqlSession中,执行相同的SQL查询时;第一次会去查询数据库,并写在缓存中,第二次会直接从缓存中取。 当执行SQL时候两次查询中间发生了增删改的操作,则SqlSession的缓存会被清空。

一级缓存 Mybatis的内部使用一个HashMap,key为hashcode statementId sql语句。Value为查询出来的结果集映射成的java对象。 Sqlsession执行insert、update、delete等操作commit后会清空该SqlSession缓存。

  • 二级缓存

二级缓存是Mapper级别的缓存,多个SqlSession去操作同一个Mapper中的sql语句,则这些SqlSession可以共享二级缓存,即二级缓存是跨SqlSession的。简单说就是同一个namespace 下的 mapper 映射文件中,用相同的sql去查询数据,会去对应的二级缓存内取结果。

二、mybatis开启本地二级缓存

1、在配置文件中添加以下代码

# 开启二级缓存

mybatis-plus.configuration.cache-enabled=true

2、在需要开启的mapper.xml中,添加以下代码(在<mapper namespace>下方)

<!--开启二级缓存-->
<cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>

eviction可用的清除策略有:

LRU – 最近最少使用:移除最长时间不被使用的对象。
FIFO – 先进先出:按对象进入缓存的顺序来移除它们。
SOFT – 软引用:基于垃圾回收器状态和软引用规则移除对象。
WEAK – 弱引用:更积极地基于垃圾收集器状态和弱引用规则移除对象。
默认的清除策略是 LRU。

flushInterval(刷新间隔)属性可以被设置为任意的正整数,设置的值应该是一个以毫秒为单位的合理时间量。 默认情况是不设置,也就是没有刷新间隔,缓存仅仅会在调用语句时刷新。

size(引用数目)属性可以被设置为任意正整数,要注意欲缓存对象的大小和运行环境中可用的内存资源。默认值是 1024。

readOnly(只读)属性可以被设置为 true 或 false。只读的缓存会给所有调用者返回缓存对象的相同实例。 因此这些对象不能被修改。这就提供了可观的性能提升。而可读写的缓存会(通过序列化)返回缓存对象的拷贝。 速度上会慢一些,但是更安全,因此默认值是 false。

3、 mapper查询参数配置

  1.  
    <select id="selectByPrimaryKey" parameterType="java.lang.Long" resultMap="BaseResultMap" useCache="true">
  2.  
    select
  3.  
    <include refid="Base_Column_List" />
  4.  
    from t_dm_cust
  5.  
    where id = #{id,jdbcType=BIGINT}
  6.  
    </select>

设置useCache=false可以禁用当前select语句的二级缓存,即每次查询都会发出sql去查询,默认情况是true,即该sql使用二级缓存。所以:针对每次查询都需要最新的数据sql,要设置成useCache=false,禁用二级缓存。

清空缓存,一般下执行完commit操作都需要刷新缓存,flushCache=true表示刷新缓存,这样可以避免数据库脏读。但是如果你不想刷新缓存只需要这么做:

  1.  
    <update id="updateByPrimaryKey" parameterType="com.sl.domain.TDmCust" flushCache=false>
  2.  
    update t_dm_cust
  3.  
    set create_time = #{createTime,jdbcType=TIMESTAMP}
  4.  
    where id = #{id,jdbcType=BIGINT}
  5.  
    </update>

4、启动应用发送查询请求

打开谷歌浏览器发送查询请求时可以看到控制台有sql打印出来。再用IE浏览器发送查询请求发现第二次未打出sql,说明第二次sql查询已经走了mybatis二级缓存。

第一次谷歌浏览器:

学新通

 第二次IE浏览器:

Cache Hit Ratio [com.sl.mapper.TDmCustMapper]: 0.5714285714285714

学新通

总结:

1、当为select查询语句时:

flushCache默认为false,表示任何时候语句被调用,都不会去清空本地缓存和二级缓存。

useCache默认为true,表示会将本条语句的结果进行二级缓存。

2、当为insert、update、delete语句时:

flushCache默认为true,表示任何时候语句被调用,都会导致本地缓存和二级缓存被清空。

useCache属性在该情况下没有。

三、使用redis开启二级缓存
 

1、在上面基础架构搭建好之后,加上redis maven配置

  1.  
    <dependency>
  2.  
    <groupId>org.springframework.boot</groupId>
  3.  
    <artifactId>spring-boot-starter-data-redis</artifactId>
  4.  
    </dependency>

2、在配置文件中加上redis配置

spring.redis.host=localhost
spring.redis.port=6379

3、因为这个类不是Spring管理的,所以通过MyBatisRedisSpringContext从ioc容器里获取redisTemplate类

  1.  
    package com.sl.config;
  2.  
     
  3.  
    import org.springframework.beans.BeansException;
  4.  
    import org.springframework.beans.factory.DisposableBean;
  5.  
    import org.springframework.context.ApplicationContext;
  6.  
    import org.springframework.context.ApplicationContextAware;
  7.  
    import org.springframework.stereotype.Component;
  8.  
     
  9.  
    /**
  10.  
    * @package: com.sl.config
  11.  
    * @author: shuliangzhao
  12.  
    * @description:
  13.  
    * @date 2022/10/4 16:09
  14.  
    */
  15.  
    @Component
  16.  
    public class MyBatisRedisSpringContext implements ApplicationContextAware, DisposableBean {
  17.  
     
  18.  
    private static ApplicationContext applicationContext = null;
  19.  
     
  20.  
    @Override
  21.  
    public void destroy() throws Exception {
  22.  
     
  23.  
    }
  24.  
     
  25.  
    @Override
  26.  
    public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
  27.  
    MyBatisRedisSpringContext.applicationContext = applicationContext;
  28.  
    }
  29.  
     
  30.  
    public static ApplicationContext getApplicationContext() {
  31.  
    return applicationContext;
  32.  
    }
  33.  
     
  34.  
    public static <T> T getBean(String name) {
  35.  
    return (T)applicationContext.getBean(name);
  36.  
    }
  37.  
     
  38.  
    public static <T> T getBean(Class clz) {
  39.  
    return (T)applicationContext.getBean(clz);
  40.  
    }
  41.  
     
  42.  
    }
学新通

 4、mapper文件配置

  <cache type="com.sl.cache.MybatisRedisCache" />

 5、启动应用发送请求

第一次谷歌浏览器:

通过sql语句查询数据库,没有走缓存。

学新通

 第二次用IE浏览器查询可以看到走了redis缓存。

学新通

 总结,以上为两种mybatis二级缓存实现方式,希望能帮到大家。源码请移步mybatis二级缓存

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhgaaaea
系列文章
更多 icon
同类精品
更多 icon
继续加载