首页 > 其他分享 >mybatis、mybatis-plus的二级缓存使用

mybatis、mybatis-plus的二级缓存使用

时间:2023-10-16 19:58:42浏览次数:30  
标签:缓存 return redis 二级缓存 plus mybatis import public redisTemplate

需求

因有些数据查询量很大,很费数据库资源,且每次查询都是不怎么变更的数据,所以需要通过缓存进行减轻数据库压力,继而选择通过myabtis的二级缓存来实现。

使用步棸

第一步:yml配置需开启mybatis-plus的二级缓存。

# MyBatis Plus的配置项
mybatis-plus:
  configuration:
    # 是否开启缓存
    cache-enabled: true

第二步:如果使用mybatis-plus的二级缓存,则须在数据层(dao层)通过@CacheNamespace注解来指定redis的缓存实现工具类。

点击查看MybatisRedisCache 缓存工具类代码
import cn.hutool.extra.spring.SpringUtil;
import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
import lombok.extern.slf4j.Slf4j;
import org.apache.ibatis.cache.Cache;
import org.springframework.data.redis.core.RedisTemplate;

import java.util.Set;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.locks.ReadWriteLock;
import java.util.concurrent.locks.ReentrantReadWriteLock;

/**
 * MybatisRedisCache 缓存工具类
 * Title: MybatisRedisCache
 * Description: redis缓存工具类
 *
 * @author lcl
 */
@Slf4j
public class MybatisRedisCache implements Cache
{
    private final ReadWriteLock readWriteLock = new ReentrantReadWriteLock();
    // cache instance id
    private final String id;
    // 缓存模板
    private RedisTemplate redisTemplate;
    // redis过期时间
    private static final long EXPIRE_TIME_IN_MINUTES = 30;

    public MybatisRedisCache(String id)
    {
        if (id == null)
        {
            throw new IllegalArgumentException("Cache instances require an ID");
        }
        this.id = id;
    }

    @Override
    public String getId()
    {
        return id;
    }

    /**
     * Put query result to redis
     *
     * @param key
     * @param value
     */
    @Override
    public void putObject(Object key, Object value)
    {
        try
        {
            redisTemplate = getRedisTemplate();
            if (value != null)
            {
                redisTemplate.opsForValue().set(key.toString(), value, EXPIRE_TIME_IN_MINUTES, TimeUnit.MINUTES);
            }
            log.debug("Put query result to redis");
        }
        catch (Throwable t)
        {
            log.error("Redis put failed", t);
        }


    }

    /**
     * Get cached query result from redis
     *
     * @param key
     * @return
     */
    @Override
    public Object getObject(Object key)
    {
        try
        {
            redisTemplate = getRedisTemplate();
            log.debug("Get cached query result from redis");
            return redisTemplate.opsForValue().get(key.toString());
        }
        catch (Throwable t)
        {
            log.error("Redis get failed, fail over to db", t);
            return null;
        }
    }

    /**
     * Remove cached query result from redis
     *
     * @param key
     * @return
     */
    @Override
    @SuppressWarnings("unchecked")
    public Object removeObject(Object key)
    {
        try {
            redisTemplate = getRedisTemplate();
            redisTemplate.delete(key.toString());
            log.debug("Remove cached query result from redis");
        } catch (Throwable t) {
            log.error("Redis remove failed", t);
        }
        return null;
    }

    /**
     * Clears this cache instance
     */
    @Override
    public void clear()
    {
        redisTemplate = getRedisTemplate();
        Set<String> keys = redisTemplate.keys("*:" + this.id + "*");
        if (!CollectionUtils.isEmpty(keys))
        {
            redisTemplate.delete(keys);
        }
        log.debug("Clear all the cached query result from redis");
    }

    /**
     * This method is not used
     *
     * @return
     */
    @Override
    public int getSize()
    {
        return 0;
    }

    @Override
    public ReadWriteLock getReadWriteLock()
    {
        return readWriteLock;
    }

    private RedisTemplate getRedisTemplate()
    {
        if (redisTemplate == null) {
            redisTemplate = SpringUtil.getBean("redisTemplate");
        }
        return redisTemplate;
    }
}

使用缓存注解

第三步:如果想即使用mybatis-plus又想使用mybatis的xml手写sql高级查询,则需在xml文件中增加<cache-ref>标签,并配置
命名空间。

<!--开启缓存-->
    <cache-ref namespace="你的xml位置"/>

使用缓存标签

第四步:返回的数据对象需实现Serializable序列化,否则会报错;因为开启二级缓存,一级缓存会写到磁盘中,二级缓存会写到内存中;

响应对象序列化

结果

标签:缓存,return,redis,二级缓存,plus,mybatis,import,public,redisTemplate
From: https://www.cnblogs.com/lin02/p/17768202.html

相关文章

  • MyBatis Plus 操作 达梦数据库
    MyBatisPlus操作达梦数据库  一、准备MyBatisPlus相关依赖包MyBatisPlus依赖包下载地址:JAVA_Mybatis_Plus_lib.zip下载加压后,效果如下: ......
  • Mybatis自定义TypeHandler完成字段加解密And枚举数据处理
    Mybatis自定义TypeHandler完成字段加解密And枚举数据处理新增And查询对枚举数据处理定义枚举@GetterpublicenumUserEnum{HOLD_A_POST("在职",10),RESIGN("离职",20);privateStringname;privateIntegervalue;UserEnum(Stringname,......
  • Mybatis使用SELECT LAST_INSERT_ID()返回0问题避坑
    Mybatis使用SELECTLAST_INSERT_ID()返回0问题避坑SELECTLAST_INSERT_ID()用于返回最后插入表中数据的主键值,一般用于表主键自增且需要用到该自增的主键值的情况<insertid="insertOrder"parameterType="com.example.bobosapce.Entity.WorkOrder">INSERTINTOWORKOR......
  • mybatisplus3.5.3版本,数据权限如何使用
    1、添加依赖<?xmlversion="1.0"encoding="UTF-8"?><projectxmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.......
  • nbcio-boot升级springboot、mybatis-plus和JSQLParser后的LocalDateTime日期json问题
    升级后,运行显示项目的时候出现下面错误2023-08-1210:57:39.174[http-nio-8080-exec-3][1;31mERROR[0;39m[36morg.jeecg.common.aspect.DictAspect:104[0;39m-json解析失败Java8date/timetype`java.time.LocalDateTime`notsupportedbydefault:addModule"com.faster......
  • nbcio-boot升级到3.1后出现online表单新增报错       nbcio-boot升级springboot、
        nbcio-boot升级springboot、mybatis-plus和JSQLParser后出现新增online表单的时候报错,如下: 2023-08-1321:18:01.292[http-nio-8080-exec-12][1;31mERROR[0;39m[36mo.jeecg.common.exception.JeecgBootExceptionHandler:69[0;39m-Handlerdispatchfailed;neste......
  • Mybatis-Flex核心功能之@Column
    1、是什么?MyBatis-Flex提供了@Column用来对字段进行更多的配置public@interfaceColumn{/***字段名称*/Stringvalue()default"";/***是否忽略该字段,可能只是业务字段,而非数据库对应字段*/booleanignore()defaultfal......
  • MybatisPlus的动态表名插件
          ......
  • PowerShell IDE - PowerShellPlus 使用(2)
    PowerShellPlus提供的快速点击库的第二部分是活动目录(ActiveDirectory),Windows的活动目录ActiveDirectory是自Windows2000的目录服务,它取代了NT4.0版中的安全帐户管理器(SAM)。ActiveDirectory由目录林、域、组织单位、容器和对象等组成。PowerShell也提供了强大的AD管理Cmdle......
  • Mybatis xml中in的用法
    一、前端多选传字符串类型给后端,用逗号(,)分隔开后端用String类型接收该字段/***所属部门编码list*/@ApiModelProperty(name="departmentCodeList",value="所属部门编码集")privateStringdepartmentCodeList;mybatis中写法如下:<iftest="vo.departmentC......