苍穹外卖--在redis中缓存菜品数据,加快查询速度

修改用户端接口 DishController 的 list 方法,加入缓存处理逻辑:

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

        String key="dish_"+categoryId;
        List<DishVO> list1= (List<DishVO>) redisTemplate.opsForValue().get(key);
        if(list1 != null && list1.size() > 0){
            //如果存在,直接返回,无须查询数据库
            return Result.success(list1);
        }
        Dish dish = new Dish();
        dish.setCategoryId(categoryId);
        dish.setStatus(StatusConstant.ENABLE);//查询起售中的菜品

        List<DishVO> list = dishService.listWithFlavor(dish);
        //如果不存在,查询数据库,将查询到的数据放入redis中
        redisTemplate.opsForValue().set(key, list);
        return Result.success(list);
    }
}

调用清理缓存的方法,保证数据一致性:

1). 新增菜品优化

java 复制代码
	/**
     * 新增菜品
     *
     * @param dishDTO
     * @return
     */
    @PostMapping
    @ApiOperation("新增菜品")
    public Result save(@RequestBody DishDTO dishDTO) {
        log.info("新增菜品:{}", dishDTO);
        dishService.saveWithFlavor(dishDTO);

        //清理缓存数据
        String key = "dish_" + dishDTO.getCategoryId();
        cleanCache(key);
        return Result.success();
    }

2). 菜品批量删除优化

java 复制代码
	/**
     * 菜品批量删除
     *
     * @param ids
     * @return
     */
    @DeleteMapping
    @ApiOperation("菜品批量删除")
    public Result delete(@RequestParam List<Long> ids) {
        log.info("菜品批量删除:{}", ids);
        dishService.deleteBatch(ids);

        //将所有的菜品缓存数据清理掉,所有以dish_开头的key
        cleanCache("dish_*");

        return Result.success();
    }

3). 修改菜品优化

java 复制代码
	/**
     * 修改菜品
     *
     * @param dishDTO
     * @return
     */
    @PutMapping
    @ApiOperation("修改菜品")
    public Result update(@RequestBody DishDTO dishDTO) {
        log.info("修改菜品:{}", dishDTO);
        dishService.updateWithFlavor(dishDTO);

        //将所有的菜品缓存数据清理掉,所有以dish_开头的key
        cleanCache("dish_*");

        return Result.success();
    }

4). 菜品起售停售优化

java 复制代码
	/**
     * 菜品起售停售
     *
     * @param status
     * @param id
     * @return
     */
    @PostMapping("/status/{status}")
    @ApiOperation("菜品起售停售")
    public Result<String> startOrStop(@PathVariable Integer status, Long id) {
        dishService.startOrStop(status, id);

        //将所有的菜品缓存数据清理掉,所有以dish_开头的key
        cleanCache("dish_*");

        return Result.success();
    }
相关推荐
小饼干在学嘎瓦26 分钟前
本地缓存和分布式缓存如何选择?
分布式·缓存
提笔了无痕27 分钟前
RAG存储策略中.md格式的切片与存储怎么处理
数据库·ai·rag
陳土34 分钟前
DuckDB精读——基于Getting started with DuckDB
数据库·oracle
凯瑟琳.奥古斯特1 小时前
数据库原理选择题精选
数据库·python·职场和发展
曹牧2 小时前
C#:主线程能够捕获到子线程中的异常
开发语言·数据库·c#
朝阳5812 小时前
MongoDB 副本集从零搭建到生产可用
数据库·mongodb
雨辰AI2 小时前
SpringBoot3 整合达梦 DM9 超详细入门实战|从零搭建可直接上线
数据库·微服务·架构·政务
我是一颗柠檬3 小时前
【MySQL全面教学】MySQL性能优化实战Day13(2026年)
数据库·后端·sql·mysql·性能优化·database
AI人工智能+电脑小能手3 小时前
【大白话说Java面试题 第84题】【Mysql篇】第14题:为什么用 InnoDB 存储引擎的表建议用整型的自增主键?
java·开发语言·数据库·mysql·面试
张彦峰ZYF3 小时前
检索增强生成(RAG)系统的基础:全面深入矢量数据库
数据库·大模型·rag