【精品】电商项目 中 基于SPU与SKU的 商品 数据库表设计

在这里插入图片描述

商品分类表:tb_product_category

该表主要是描述商品的分类。此表采用无限层级树状数据结构,程序使用递归算法来遍历分类下的所有子分类,pid是父级分类, paid=null时说明是根节点, 属于一级类别;

属性:id,pid,name等

商品表表(即spu表):tb_product

存储商品信息。表中关键字段是category_id和attribute_list两个字段:

  • category_id:记录商品属于哪个分类, 用于通过分类进行商品搜索;

  • attribute_list:记录的是所有属性的集合,这个字段采用json格式存储,便于前端解析;前端解析后可以在页面显示出商品的所有属性, 用户点击选择出属性组合后,前端可以拼接成形如{"内存":"2G","颜色":"红色","尺寸":"20cm"}的json格式加上商品id在(商品规格表 tb_product_specs)查询到具体的单品,随即获取到具体单品的库存和价格等信息;

属性:id,category_id,name,attribute_list等

商品规格表(即:sku表):tb_product_specs

存储商品的具体规格单品,即sku。sku表保存的是具体的单品信息,比如具体规格的库存和价格等,核心字段是product_id和product_specs:

  • product_id 记录的是spu表中的商品id

  • product_specs 记录的是该单品具体的属性值(规格值);

属性:id,product_id,product_specs等

属性key表:tb_attribute_key

用于存储sku的属性,比如:机身颜色,存储容量

属性key表和属性value表仅用于管理后台页面生成属性选项,管理员在发布新商品时勾选属性,方便规格的录入和保证正确性;

属性value表:tb_attribute_value

用于存储sku的属性值,比如:6+128G,8+128G,8+256G

总结

上述数据表设计方案适用于商品类别差异不是很大的情形,通过表的字段可以发现不同的商品之间变化的信息只有 attribute_list 字段, 而这个字段通过json来存储各种不同的属性集合, 同样sku表中变化的字段只有 product_specs 也是通过json来存储各种不同属性组合。

改进方案


将tb_product、tb_brand、tb_product_specs表中的info字段分别抽取到单独的表中。

附:相关表的SQL文件


/*

Navicat Premium Data Transfer

Source Server : localhost

Source Server Type : MySQL

Source Server Version : 80025

Source Host : localhost:3306

Source Schema : test

Target Server Type : MySQL

Target Server Version : 80025

File Encoding : 65001

Date: 07/12/2021 11:19:44

*/

SET NAMES utf8mb4;

SET FOREIGN_KEY_CHECKS = 0;


– Table structure for tb_attribute_key


DROP TABLE IF EXISTS tb_attribute_key;

CREATE TABLE tb_attribute_key (

id int(0) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT ‘编号’,

attribute_name varchar(22) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT ‘属性名’,

priority int(0) UNSIGNED NULL DEFAULT NULL COMMENT ‘优先级’,

category_id int(0) UNSIGNED NULL DEFAULT NULL COMMENT ‘类别编号’,

create_time datetime(0) NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT ‘创建时间’,

update_time datetime(0) NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT ‘更新时间’,

PRIMARY KEY (id) USING BTREE,

INDEX category_id(category_id) USING BTREE,

CONSTRAINT tb_attribute_key_ibfk_1 FOREIGN KEY (category_id) REFERENCES tb_product_category (id) ON DELETE RESTRICT ON UPDATE RESTRICT

) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = ‘属性key表’ ROW_FORMAT = Dynamic;


– Records of tb_attribute_key



– Table structure for tb_attribute_value


DROP TABLE IF EXISTS tb_attribute_value;

CREATE TABLE tb_attribute_value (

id int(0) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT ‘编号’,

attribute_id int(0) UNSIGNED NULL DEFAULT NULL COMMENT ‘属性编号’,

priority int(0) UNSIGNED NULL DEFAULT NULL COMMENT ‘优先级’,

attribute_value varchar(22) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT ‘属性值’,

create_time datetime(0) NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT ‘创建时间’,

update_time datetime(0) NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT ‘更新时间’,

PRIMARY KEY (id) USING BTREE,

INDEX category_id(attribute_id) USING BTREE,

CONSTRAINT tb_attribute_value_ibfk_1 FOREIGN KEY (attribute_id) REFERENCES tb_attribute_key (id) ON DELETE RESTRICT ON UPDATE RESTRICT

) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = ‘属性value表’ ROW_FORMAT = Dynamic;


– Records of tb_attribute_value



– Table structure for tb_brand


DROP TABLE IF EXISTS tb_brand;

CREATE TABLE tb_brand (

id int(0) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT ‘品牌编号’,

name varchar(18) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT ‘品牌名称’,

logo varchar(180) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT ‘品牌LOGO’,

info varchar(220) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT ‘品牌描述’,

status tinyint(0) UNSIGNED NULL DEFAULT 1 COMMENT ‘状态 1上架 2下架’,

create_time datetime(0) NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT ‘创建时间’,

update_time datetime(0) NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT ‘更新时间’,

PRIMARY KEY (id) USING BTREE

) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = ‘品牌表’ ROW_FORMAT = Dynamic;


– Records of tb_brand



– Table structure for tb_product


DROP TABLE IF EXISTS tb_product;

CREATE TABLE tb_product (

id int(0) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT ‘商品编号’,

name varchar(28) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT ‘商品名称’,

attribute_list json NULL COMMENT ‘商品属性列表’,

category_id int(0) UNSIGNED NULL DEFAULT NULL COMMENT ‘类别编号’,

brand_id int(0) UNSIGNED NULL DEFAULT NULL COMMENT ‘品牌编号’,

status tinyint(0) UNSIGNED NULL DEFAULT NULL COMMENT ‘状态 1上架 2下架’,

info varchar(180) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT ‘备注’,

create_time datetime(0) NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT ’ 创建时间’,

update_time datetime(0) NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT ’ 更新时间’,

PRIMARY KEY (id) USING BTREE,

INDEX category_id(category_id) USING BTREE,

INDEX brand_id(brand_id) USING BTREE,

CONSTRAINT tb_product_ibfk_1 FOREIGN KEY (category_id) REFERENCES tb_product_category (id) ON DELETE RESTRICT ON UPDATE RESTRICT,

CONSTRAINT tb_product_ibfk_2 FOREIGN KEY (brand_id) REFERENCES tb_brand (id) ON DELETE RESTRICT ON UPDATE RESTRICT

) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = ‘商品表(SPU)’ ROW_FORMAT = Dynamic;


最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
7DA6cSZ-1715795087438)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

  • 18
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值