删除与还原商品
需求分析#
商品列表中的删除商品功能,并非真正的删除(物理删除),而是采用逻辑删除将删除标记的字段设置为1.
在回收站中有还原商品的功能,将删除标记的字段设置为0
在回收站中有删除商品的功能,是真正的物理删除,将数据从数据库中删除掉。
实现思路#
商品列表中的删除商品,执行逻辑删除,修改spu表is_delete字段为1
商品回收站中的还原商品,修改spu表is_delete字段为0
商品回收站中的删除商品,执行delete操作,进行物理删除
代码实现#
逻辑删除商品#
修改SpuServiceImpl的delete方法
/** * 删除 * @param id */ @Override public void delete(String id){ Spu spu = spuMapper.selectByPrimaryKey(id); //检查是否下架的商品 if(!spu.getIsMarketable().equals("0")){ throw new RuntimeException("必须先下架再删除!"); } spu.setIsDelete("1");//删除 spu.setStatus("0");//未审核 spuMapper.updateByPrimaryKeySelective(spu); }
还原被删除的商品#
(1)SpuService新增方法
/** * 恢复数据 * @param id */ public void restore(String id);
(2)SpuServiceImpl实现此方法
/** * 恢复数据 * @param id */ @Override public void restore(String id) { Spu spu = spuMapper.selectByPrimaryKey(id); //检查是否删除的商品 if(!spu.getIsDelete().equals("1")){ throw new RuntimeException("此商品未删除!"); } spu.setIsDelete("0");//未删除 spu.setStatus("0");//未审核 spuMapper.updateByPrimaryKeySelective(spu); }
(3)SpuController新增方法
/** * 恢复数据 * @param id * @return */ @PutMapping("/restore/{id}") public Result restore(@PathVariable String id){ spuService.restore(id); return new Result(); }
物理删除商品#
判断必须逻辑删除商品才能物理删除
(1)SpuService 新增方法
/** * 物理删除 * @param id */ public void realDelete(String id);
(2)SpuServiceImpl 实现方法
@Override public void realDelete(String id) { Spu spu = spuMapper.selectByPrimaryKey(id); //检查是否删除的商品 if(!spu.getIsDelete().equals("1")){ throw new RuntimeException("此商品未删除!"); } spuMapper.deleteByPrimaryKey(id); }
(3)SpuController新增方法
/** * 物理删除 * @param id * @return */ @DeleteMapping("/realDelete/{id}") public Result realDelete(@PathVariable String id){ spuService.realDelete(id); return new Result(); }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)