java实现商品sku_商品SKU功能设计与优化

本文介绍了电商项目中商品SKU功能的设计与优化过程。原有的设计存在表结构固化、SKU ID变更导致的问题。优化后,使用JSON存储动态销售属性,解决了扩展性和ID匹配问题。在更新商品信息时,通过逻辑判断实现SKU的新增、修改和删除,保持原有ID不变。
摘要由CSDN通过智能技术生成

SpringBoot实战电商项目mall(30k+star)地址:github.com/macrozheng/…

摘要

原来的商品SKU设计存在着两个问题,一个是SKU表设计上面比较固化,无法扩展。另一个是当修改了商品信息之后,商品SKU的ID会发生变化,由于购物车表和订单商品表都关联了商品SKU的ID,这样就会导致匹配不上。最近对这两个问题做了点优化,下面来聊聊优化的思路。

商品的SPU和SKU

首先我们来了解下商品SPU和SKU的概念,可能很多没有接触过电商的朋友都不了解。

SPU(Standard Product Unit ):指的是标准商品单位,商品信息聚合的最小单位,是一组可复用、易检索的标准化信息的集合,该集合描述了一个商品的特性;

SKU(Stock Keeping Unit):库存量单位,是物理上不可分割的最小存货单元。

举个例子:比如说现在有个手机商品叫小米8,小米8有不同的属性,比如有它有黑色和蓝色的,有32G和64G版本的。此时小米8就是一个SPU,而小米8黑色64G就是一个SKU。

0d0be993507282d65b7b27f66ab71c8a.png

商品的SKU设计

以前的设计

商品的SKU信息是存储在pms_sku_stock表中的,使用sp1、sp2、sp3这三个属性来存储商品的销售属性,这样做很不灵活,也难以扩展。

34f74a6357043a6ef13f0601ec47ac21.png

这种做法也带来了后续的问题,比如我们的购物车和订单都会需要存储销售属性,这样的话都会需要添加sp1、sp2、sp3的属性。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值