PHP商品无限规格的实现思路(图文)

知识技术 2022-05-03 09:31 820
转载请务必注明: 来源:《建站管家》https://www.df81.com/news/347.html

在电子商城项目开发中, 会存在同一种商品存在不同规格的情况, 如图某型号手机在售卖时用户可以选择的不同规格:


这里商品的库存量单位(SKU)便不再是该商品, 而是到具体属性组合出的规格, 每种规格可能会有不同的售价、运费与库存剩余情况, 所以用户在购买时, 不仅需要记录所购买的商品 ID, 同时也需要记录购买的该商品的具体规格。

直观分析图示中的规格情况, 网络类型、机身颜色、机身内存 属于商品不同属性的名称, 与之对应的为属性可选择的的具体值, 属于一对多关系, 在 MySQL 数据库表结构中反应出为:


# 商品属性名 CREATE TABLE `item_attr_key` ( `attr_key_id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT, # 主键, 自增 ID `item_id` INT(10) UNSIGNED NOT NULL, # 关联到商品 `attr_name` VARCHAR(50) NOT NULL, # 属性名称 PRIMARY KEY (`attr_key_id`) ); # 商品属性值 CREATE TABLE `item_attr_val` ( `attr_key_id` INT(10) UNSIGNED NULL DEFAULT NULL, # 对应 item_attr_key 表的 attr_key_id, 完成一对多关联 `item_id` INT(10) UNSIGNED NULL DEFAULT NULL, # 关联到商品 `symbol` INT(10) NULL DEFAULT NULL, # 属性编码 `attr_value` VARCHAR(255) NULL DEFAULT NULL # 属性值 );


加入数据后表内容如图:


symbol 字段是对指定商品 ID 下的属性值的一个序号标记, 是为了提高在后面使用到时的检索效率。该值在不同商品间可以重复, 在同一商品的属性中需要保证唯一。

以上就完成了商品 ID 为 6 的商品多属性的存储工作。

为了能够记录和快速查询出每种属性组合出的商品的价格、库存等信息, 我们还需要张表来维护这部分数据, 建立 item_sku 表:


# 商品库存量单位表 CREATE TABLE `item_sku` ( `sku_id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT, # 主键, 自增 ID `item_id` INT(10) UNSIGNED NOT NULL DEFAULT '0', # 关联到商品 `attr_symbol_path` VARCHAR(255) NOT NULL, # 属性组合出的规格路径 `price` DOUBLE(15,2) NOT NULL DEFAULT '0.00', # 价格 `freight` DOUBLE(15,2) NULL DEFAULT '0.00', # 运费 `stock` INT(10) UNSIGNED NOT NULL DEFAULT '0', # 库存数量 PRIMARY KEY (`sku_id`) );


该表是用户在添加完商品属性后, 由系统负责生成的该商品所有的可以选择的属性组合方案, attr_symbol_path 字段即是该商品不同属性值的 symbol 字段组合后的路径, 用来指示该规格具体指代哪些属性。

如 attr_symbol_path 字段值为 1,4,7, 则对应 item_attr_val 表中 item_sku.item_id = item_attr_val.item_id 条件下 symbol 字段值为 1, 4, 7 的属性组合: TD-LTE/FDD-LTE/TDS/WCDMA/EVDO/GSM - 深空灰 - 16GB。

将示例中具有三种网络类型、三种机身颜色、三种机身内存的属性数据生成 SKU 后的 item_sku 表数据图示:


从图中数据看出, 该商品共有27种不同规格可选, 那么这时在确定用户选择的某种规格的价格等信息时只需一条 SQL 语句即可完成:

select * from `item_sku` where `item_id`=6 and `attr_symbol_path`='1,4,7';

点赞 (0)

收藏 (0)

本站部分信息来源网络,如有侵权,请联系QQ:1062129401删除。

上一篇: 《建站管家》二次开发文档

下一篇: 百度站长平台移动站点适配规则的写法

请先登录后,再发表评论 ~ ~
发表评论
发表评论
发表帖子
广告位招租( ¥5 / 天 )
点击咨询
相关帖子

如果要判断文件是否存在,用函数 is_file(),如果要判断目录是否存在,用函数 is_dir()
用宝塔安装TP程序后,网站前台可以访问,后台无法访问,不是程序问题,而是web服务器环境配置问题(PHP配置),出现这种问题,一般是windows主机安装宝塔造成的,linux安装宝塔不会出现此错误
广告位招租( ¥3 / 天 )
点击咨询
广告位招租( ¥2 / 天 )
点击咨询
广告位招租( ¥1 / 天 )
点击咨询
最新帖子

小朋友,你爸爸是谁啊?这很单纯的,就像我们碰到别人会问:你吃过饭了吗?类似;许多人初次相识,经常会问:你是做什么的啊?你做什么,好像决定你收入的高低,你,资产的范围
1、升级框架到ThinkPHP8.0.3【要求PHP8.1+环境,推荐PHP8.1】 2、启用/禁用调试模式等小细节改进
后台点击生成站点地图 一直转圈圈没有反应,
在线客服