8.10 用redis实现缓存功能和Spring Cache

什么是缓存?

缓存(Cache), 就是数据交换的缓冲区,俗称的缓存就是缓冲区内的数据,一般从数据库中获取,存储于本地代码。

通过Redis来缓存数据,减少数据库查询操作;

逻辑
每个分类的菜品保存一份缓存数据
数据库菜品数据有变更时清理缓存数据

如何将商品数据缓存起来。

bash 复制代码
   @GetMapping("/list")
    @ApiOperation("根据分类id查询菜品")
    public Result<List<DishVO>> list(Long categoryId) {

        //查询redis里面是否存在数据类;
    String key="dish_"+categoryId;
        //如果存在直接返回
        List<DishVO> list = (List<DishVO>) redisTemplate.opsForValue().get(key);

     if (list!=null&&list.size()>0){
         return Result.success(list);
     }
        //不存在需要查询数据库,并保存至redis里面
        Dish dish = new Dish();
        dish.setCategoryId(categoryId); //设置套餐的id

        dish.setStatus(StatusConstant.ENABLE);//查询起售中的菜品

         list = dishService.listWithFlavor(dish);

        redisTemplate.opsForValue().set(key,list); //将他缓存起来
        return Result.success(list);

    }

控制台没有sql了,说明缓存已经实现了。

二 数据内容发生改变的时候,需要修改redis的内容。

修改操作、删除菜品、起售或者停售、新建菜品也需要缓存数据

bash 复制代码
private void  cleanCache(String pattern){

        Set keys = redisTemplate.keys(pattern);
        redisTemplate.delete(keys); //支持删除集合的

    }

删除对应的缓存数据

缓存套餐功能

spring Cache 实现了基于注解的缓存功能

bash 复制代码
   <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-cache</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>

对应的maven坐标

注解开发

Cacheable 在方法执行前查询缓存是否有数据;

相关推荐
VT.馒头7 分钟前
【力扣】2622. 有时间限制的缓存
javascript·算法·leetcode·缓存·typescript
短剑重铸之日14 分钟前
《7天学会Redis》Day 3 - 持久化机制深度解析
java·redis·后端·缓存
qq_4351395724 分钟前
多级缓存(Caffeine+Redis)技术实现文档
数据库·redis·缓存
萧曵 丶25 分钟前
Spring 全套高频面试题(由浅到深 完整版)
java·后端·spring
超级种码1 小时前
Redis:Redis持久化机制
数据库·redis·bootstrap
am心2 小时前
学习笔记-缓存&添加购物车
笔记·学习·缓存
雨中飘荡的记忆2 小时前
Spring Security入门:构建安全应用
spring
Codeking__2 小时前
Redis初识——Redis的基本特性
数据库·redis·缓存
零度@2 小时前
2026 轻量级消息队列 Redis Stream
前端·redis·bootstrap
難釋懷3 小时前
安装Redis
数据库·redis·缓存