基于Redis添加商铺查询缓存

文章目录

1.流程图

2.实现逻辑

Service层

java 复制代码
public Result queryById(Long id) {
        // 1.从redis中查询店铺缓存
        String shopJson = stringRedisTemplate.opsForValue().get("cache:shop:"+id);
        // 2.判断缓存是否存在
        if (StrUtil.isNotBlank(shopJson)) {
            Shop shop = JSONUtil.toBean(shopJson, Shop.class);
            return Result.ok(shop);
        }
        // 3.不存在,根据id查询数据库
        Shop shop = getById(id); // mybatisplus功能
        // 4.不存在,返回错误
        if (shop == null) {
            return Result.fail("店铺数据不存在");
        }
        // 存在,写入redis
        stringRedisTemplate.opsForValue().set("cache:shop:"+id, JSONUtil.toJsonStr(shop));
        return Result.ok(shop);
        
    }
相关推荐
pipip.3 分钟前
Go原生高性能内存网关IMS,比Redis更快
开发语言·redis·golang
q***71851 小时前
常见的 Spring 项目目录结构
java·后端·spring
修行者Java3 小时前
Redis 核心功能全解析:功能描述、应用场景与 Java 实战
redis
xie_pin_an3 小时前
Redis 核心命令速查表
数据库·redis·缓存
小兵张健3 小时前
Java + Spring 到 Python + FastAPI (一)
java·python·spring
aniden4 小时前
Swagger从入门到实战
java·开发语言·spring
苦学编程的谢4 小时前
Redis_11_类型补充+命令补充+RESP
数据库·redis·缓存
hzk的学习笔记4 小时前
Redisson 和 Jedis 的区别
数据库·redis·缓存
q***47185 小时前
解决 Tomcat 跨域问题 - Tomcat 配置静态文件和 Java Web 服务(Spring MVC Springboot)同时允许跨域
java·前端·spring
无心水5 小时前
【中间件:Redis】5、Redis分布式锁实战:从基础实现到Redisson高级版(避坑指南)
redis·分布式·中间件·redisson·后端面试·redis分布式锁·分布式系统