当前位置: 首页 > backend >正文

#黑马点评#(二)商户查询缓存

目录

一 商户查询缓存

1 什么是缓存

2 添加Redis缓存

1 商铺缓存

2 店铺类型缓存

3 缓存的更新策略


一 商户查询缓存

1 什么是缓存

缓存就是数据交换的缓冲区(俗称Cache)是存储数据的临时地方,一般读写性能较高。

2 添加Redis缓存

1 商铺缓存

流程图逻辑展示

实现:

Controller控制层

    /*** 根据id查询商铺信息** @param id 商铺id* @return 商铺详情数据*/@GetMapping("/{id}")public Result queryShopById(@PathVariable("id") Long id) {return shopService.queryById(id);}

Service业务层(业务层接口)

    /*** 根据id查询店铺信息** @param id 店铺id* @return 店铺信息*/Result queryById(Long id);

Service业务层(业务层实现类)

逻辑:先从redis中查询商户店铺缓存判断是否存在,存在就直接返回数据,不存在就去数据库当中查询数据,再次判断数据是否存在,如果存在就将其存储到redis缓存当中如果不存在就返回错误信息。

    @Autowiredprivate StringRedisTemplate stringRedisTemplate;/*** 根据id查询商铺信息** @param id 商铺id* @return 商铺详情数据*/@Overridepublic Result queryById(Long id) {// 1.从redis中商铺缓存String shopJson = stringRedisTemplate.opsForValue().get(RedisConstants.CACHE_SHOP_KEY + id);// 2.判断是否存在if (StrUtil.isNotBlank(shopJson)) {// 3.存在,返回数据Shop shop = JSONUtil.toBean(shopJson, Shop.class);return Result.ok(shop);}// 4.不存在,根据id查询数据库Shop shop = getById(id);// 5.数据库存在,写入redis并返回if (shop != null) {stringRedisTemplate.opsForValue().set(RedisConstants.CACHE_SHOP_KEY + id, JSONUtil.toJsonStr(shop));return Result.ok(shop);}// 6.数据库不存在,返回错误return Result.fail("店铺不存在");}

缓存界面展示:

2 店铺类型缓存

Controller控制层

    @GetMapping("list")public Result queryTypeList() {List<ShopType> typeList = typeService.queryTypeList();return Result.ok(typeList);}

Service业务层(业务层接口)

    /*** 查询所有商铺类型,并添加排序值sort_value** @return 所有商铺类型列表*/List<ShopType> queryTypeList();

Service业务层(业务层实现类)

    @Autowiredprivate StringRedisTemplate stringRedisTemplate;/*** 查询所有商铺类型(带缓存的查询)** @return*/@Overridepublic List<ShopType> queryTypeList() {// 1.从redis中商铺缓存String shopTypeJson = stringRedisTemplate.opsForValue().get("cache:shop:type");// 2.判断是否存在if (StrUtil.isNotBlank(shopTypeJson)) {List<ShopType> shopTypes = JSONUtil.toList(shopTypeJson, ShopType.class);// 3.存在,返回数据return shopTypes;}// 4.不存在,查询数据库List<ShopType> shopTypes = query().orderByAsc("sort").list();// 5.数据库存在,写入redisif (shopTypes != null) {stringRedisTemplate.opsForValue().set("cache:shop:type", JSONUtil.toJsonStr(shopTypes));return shopTypes;}// 6.数据库不存在,返回nullreturn null;}

3 缓存的更新策略

我们再业务当中会出现对数据库当中的内容已经修改了但是缓存当中没有实时更新,这样我们就需要设置合适的缓存更新策略进行弥补。

修改shopController中的业务逻辑

  • 1 根据id查询店铺时,缓存未命中,则查询数据库,将数据库结果写入缓存并设置超时时间(超时剔除方案)
  • 2 根据id修改店铺时,先修改数据库再查询缓存

1 查询业务当中,我们只需要将代码中设置redis缓存的超时时间

    /*** 根据id查询商铺信息** @param id 商铺id* @return 商铺详情数据*/@Overridepublic Result queryById(Long id) {// 1.从redis中商铺缓存String shopJson = stringRedisTemplate.opsForValue().get(RedisConstants.CACHE_SHOP_KEY + id);// 2.判断是否存在if (StrUtil.isNotBlank(shopJson)) {// 3.存在,返回数据Shop shop = JSONUtil.toBean(shopJson, Shop.class);return Result.ok(shop);}// 4.不存在,根据id查询数据库Shop shop = getById(id);// 5.数据库存在,写入redis并返回if (shop != null) {stringRedisTemplate.opsForValue().set(RedisConstants.CACHE_SHOP_KEY + id, JSONUtil.toJsonStr(shop),  RedisConstants.CACHE_SHOP_TTL, TimeUnit.MINUTES);return Result.ok(shop);}// 6.数据库不存在,返回错误return Result.fail("店铺不存在");}

2 更新业务当中我们需要先将数据库当中的数据进行更新再将缓存当中的数据进行删除

controller控制层

    /*** 更新商铺信息** @param shop 商铺数据* @return 无*/@PutMappingpublic Result updateShop(@RequestBody Shop shop) {return shopService.updateData(shop);}

Service业务层(业务层接口)

    /*** 更新店铺信息(数据库与缓存都进行更新)** @param shop 店铺信息* @return 是否成功*/Result updateData(Shop shop);

Service业务层(业务层实现类)

    /*** 更新店铺信息(更新数据库以及删除缓存)** @param shop 店铺信息* @return 更新结果*/@Transactional@Overridepublic Result updateData(Shop shop) {//判断id是否存在Long id = shop.getId();if (id == null) {return Result.fail("店铺id不能为空");}//更新数据库updateById(shop);//删除缓存stringRedisTemplate.delete(RedisConstants.CACHE_SHOP_KEY + shop.getId());return Result.ok();}

http://www.xdnf.cn/news/4565.html

相关文章:

  • 新疆地区主要灾害链总结
  • 网络编程(一)
  • seamless_communication,facebook推出的开源语音翻译项目
  • 代码随想录算法训练营 Day39 动态规划Ⅶ 打家劫舍
  • 数据可视化:php+echarts实现数据可视化(包含echart安装引入)
  • 数据压缩实现案例
  • 以pytest_addoption 为例,讲解pytest框架中钩子函数的应用
  • RAG技术体系问题的系统性总结
  • C++并发编程完全指南:从基础到实践
  • BBDM学习笔记
  • Spring Boot 中 AOP 的自动装配原理
  • C语言复习笔记--自定义类型
  • Nacos源码—5.Nacos配置中心实现分析二
  • QT高级(1)QTableView自定义委托集合,一个类实现若干委托
  • C——函数递归
  • 软考冲刺——OSPF简答题
  • 仿真系统-学生选课管理
  • 数字化转型是往哪转?怎么转?
  • 第35周Zookkeeper+Dubbo Dubbo
  • 【前端笔记】CSS 选择器的常见用法
  • Cron 用法
  • 数据管道的解耦艺术:Dagster I/O管理器实现存储与逻辑分离
  • 第二章:MySQL 索引优化与高级应用
  • python的异常处理
  • CODESYS开发环境下的快捷键和软件操作汇总
  • 《C++ Templates》:有关const、引用、指针的一些函数模板实参推导的例子
  • Ubuntu 安装 Keepalived
  • Linux 系统的进阶指令详解
  • 【软件设计师:算法】3.排序算法
  • 微信小程序pinia的应用