《苍穹外卖》项目学习记录-Day7缓存套餐

embedded/2025/2/5 9:56:20/

如果使用EHCache作为缓存实现,只需要导入 EHCache的maven坐标。

·入门案例

如果使用Spring cache缓存数据,key的生成:userCache::xxx。#user.id中的.叫做对象导航。

因为id是自增的所以只输入age和name就可以了,在插入完之后它会把主键值赋值到user对象上,它是先插入到数据库,插入到数据库之后id就有值了,然后再去操作缓存数据,这个时候它就能取到id的值。

这个树形结构层次是通过:划分出来的,我们有两个:所以有一个Empty包。

Redis在存储数据的时候以Redis当中的String字符串类型进行存储,user对象已经进行的序列化。

当我们调用getById这个方法前,需要先来判断一下缓存当中,也就是Redis当中是否存在缓存数据,如果已经存在缓存数据,它就不会去查询数据库,甚至它连control的这个getById这个方法都不会调用。key的生成:userCache::xxx,xxx是动态的去取到id的值拼到这里,如果id是10则key就是userCache::10。它会拿到这个key到Redis当中来查询有没有相应的数据,如果查到了它就会直接使用这个缓存数据,就不会再去调用getById方法,如果没有查询到,它就会通过反射来调这个方法,这个方法里面就是去查数据库,把这个数据返回,这个时候它就会把返回结果缓存起来,等下一次再查询相同数据的时候,缓存中就有了。

Spring Cache底层基于代理技术,我们加入这个注解之后,Spring Cache就会为当前的controler来创建一个代理对象,我们在请求方法之前,它其实是先进入代理对象,而在代理对象里面去查询Redis,如果有数据查到之后它会直接返回,所以getById方法根本没有被调用到。

缓存里面有数据它直接返回数据,并没有发出SQL语句。

把缓存中的数据删除掉,缓存中没有这个数据,它发出SQL语句去查数据库。

·清理缓存数据

 

·清理所有的缓存数据

·缓存套餐

 由Spring Cache这个框架给我们来动态计算出Redis当中的一个key,根据下面的写法key的构成是setmealCache::后面动态跟上一个categoryId,假设categoryId是100则key算出来是setmealCache::100。Spring Cache这个框架会使用动态算出来的字符串(setmealCache::100)来作为Redis中的key来进行存储,具体的值是方法返回的结果。

·用户查询套餐数据

·商家管理端对套餐数据更改

package com.sky.controller.admin;import com.sky.dto.SetmealDTO;
import com.sky.dto.SetmealPageQueryDTO;
import com.sky.result.PageResult;
import com.sky.result.Result;
import com.sky.service.SetmealService;
import com.sky.vo.SetmealVO;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cache.annotation.CacheEvict;
import org.springframework.web.bind.annotation.*;import java.util.List;/*** 套餐管理*/
@RestController
@RequestMapping("/admin/setmeal")
@Api(tags = "套餐相关接口")
@Slf4j
public class SetmealController {@Autowiredprivate SetmealService setmealService;/*** 新增套餐* @param setmealDTO* @return*/@PostMapping@CacheEvict(cacheNames = "setmealCache",key = "#setmealDTO.categoryId")//key:setmealCache::100@ApiOperation("新增套餐")public Result save(@RequestBody SetmealDTO setmealDTO) {setmealService.saveWithDish(setmealDTO);return Result.success();}/*** 分页查询* @param setmealPageQueryDTO* @return*/@GetMapping("/page")@ApiOperation("分页查询")public Result<PageResult> page(SetmealPageQueryDTO setmealPageQueryDTO) {PageResult pageResult = setmealService.pageQuery(setmealPageQueryDTO);return Result.success(pageResult);}/*** 批量删除套餐* @param ids* @return*/@DeleteMapping@ApiOperation("批量删除套餐")@CacheEvict(cacheNames = "setmealCache",allEntries = true)public Result delete(@RequestParam List<Long> ids){setmealService.deleteBatch(ids);return Result.success();}/*** 根据id查询套餐,用于修改页面回显数据** @param id* @return*/@GetMapping("/{id}")@ApiOperation("根据id查询套餐")public Result<SetmealVO> getById(@PathVariable Long id) {SetmealVO setmealVO = setmealService.getByIdWithDish(id);return Result.success(setmealVO);}/*** 修改套餐** @param setmealDTO* @return*/@PutMapping@ApiOperation("修改套餐")@CacheEvict(cacheNames = "setmealCache",allEntries = true)public Result update(@RequestBody SetmealDTO setmealDTO) {setmealService.update(setmealDTO);return Result.success();}/*** 套餐起售停售* @param status* @param id* @return*/@PostMapping("/status/{status}")@ApiOperation("套餐起售停售")@CacheEvict(cacheNames = "setmealCache",allEntries = true)public Result startOrStop(@PathVariable Integer status, Long id) {setmealService.startOrStop(status, id);return Result.success();}
}

·测试

 ·动态代理

什么是代理?

代理思想就是被代理者没有能力,或者不愿意去完成某件事情,需要找个人(代理)代替自己去完成这件事。

动态代理主要是对被代理对象的行为进行代理。

程序为什么需要代理?代理长什么样子?

如对象如果嫌身上干的事太多的话,可以通过代理来转移部分职责。

对象有什么方法想被代理,代理就一定要有对应的方法。

 


http://www.ppmy.cn/embedded/159717.html

相关文章

详解Kafka并行计算架构

引言 在高流量的复杂场景下&#xff0c;Kafka 凭借卓越的性能表现脱颖而出&#xff0c;始终维持着极高的吞吐率和高效的消息消费能力&#xff0c;在众多消息队列产品中独树一帜。其稳定且强大的性能&#xff0c;不仅保障了海量数据的快速处理&#xff0c;还为各类业务的高效运行…

【cran Archive R包的安装方式】

cran Archive R包的安装方式 添加链接描述 1.包被cran移除 2.包要求的R语言版本与你电脑上的版本不相符 ad archive包的网址或者是下载到工作目录下&#xff0c;ad等于文件名 install,packages(ad repos NULL)

Java小白入门教程:LinkedList

目录 一、定义 二、作用 1、存储数据 2、动态扩容 3、提供方便的操作方法 三、使用场景 1.当你需要频繁地在列表的开头或结尾添加或删除元素时。 2.当你不需要按索引快速访问元素时&#xff0c;因为LinkedList访问元素需要从头开始遍历 3.当你不需要线程安全的数据结构…

关于matlab中rotm2eul的注释错误问题

在这里&#xff0c;写的是默认的旋转矩阵的顺序为‘ZYX’&#xff0c;对应的旋转轴的顺序为Z、Y、X。 包括网页上写的是 但是实际上&#xff0c;在实际的应用中&#xff0c;旋转的顺序应该是&#xff0c;X、Y、Z轴的顺序 即RRzRyRx 但是在矩阵运算中&#xff0c;由于YRzRyRx*X…

在Vue 3中使 echarts 图表宽度自适应变化

需求&#xff1a; 有现在这样一段使用 echarts 的 vue3 代码&#xff1a; <template><div ref"chartRef" style"width: 600px; height: 400px;"></div> </template><script setup> import {getCurrentInstance, onMounted…

kaggle视频行为分析1st and Future - Player Contact Detection

这次比赛的目标是检测美式橄榄球NFL比赛中球员经历的外部接触。您将使用视频和球员追踪数据来识别发生接触的时刻&#xff0c;以帮助提高球员的安全。两种接触&#xff0c;一种是人与人的&#xff0c;另一种是人与地面&#xff0c;不包括脚底和地面的&#xff0c;跟我之前做的这…

大一计算机的自学总结:数据结构设计相关题

前言 说实在的&#xff0c;感觉这种设计数据结构的题比链表题还要ex&#xff0c;尤其是当哈希表和链表一起上的时候&#xff01; 一、设计有setAll功能的哈希表 #include <bits/stdc.h> using namespace std;int cnt0,setAllTime0,setAllValue; map<int,pair<in…

九. Redis 持久化-RDB(详细讲解说明,一个配置一个说明分析,步步讲解到位)

九. Redis 持久化-RDB(详细讲解说明&#xff0c;一个配置一个说明分析&#xff0c;步步讲解到位) 文章目录 九. Redis 持久化-RDB(详细讲解说明&#xff0c;一个配置一个说明分析&#xff0c;步步讲解到位)1. RDB 概述2. RDB 持久化执行流程3. RDB 的详细配置4. RDB 备份&恢…