商品规格表结构设计

商品规格包括规格组合、规格项,规格项为规格组的成员。

规格组

|-规格项:规格值

|-规格项:规格值

规格组

|-规格项:规格值

|-规格项:规格值

同一类商品的规格相同。

方案一

使用多个表存储商品规格。在已有的商品分类表和商品表的基础上,增加商品规格分组表、商品规格项表、商品规格值表。

表设计

商品表:tb_item

列名       类型       键   说明

item_id  bigint     P     商品id

cat_id    bigint     F     商品分类id

商品分类表:tb_item_cat

列名       类型       键   说明

cat_id    bigint     P     商品分类id

商品规格组表:tb_item_param_group

列名       类型       键   说明

group_id bigint     P     商品规格组id

group_name varchar         商品规格组名称

cat_id    bigint     F     商品分类id

商品规格项表:tb_item_param_key

列名       类型       键   说明

key_id    bigint     P     商品规格项id

key_name    varchar         商品规格项名称

group_id bigint     F     商品规格组id

商品规格值表:tb_item_param_value

列名       类型       键   说明

item_id  bigint     P     商品id(联合主键)

key_id    bigint     P     商品规格项id(联合主键)

param_value varchar         商品规格信息

表关系

查询语句

查询某id商品信息,规格组、规格项、规格值:

SELECT

pg.group_name,

pk.key_name,

pv.param_value

FROM

tb_item_param_value pv

LEFT JOIN tb_item_param_key pk ON pv.key_id = pk.key_id

LEFT JOIN tb_item_param_group pg ON pk.group_id = pg.group_id

WHERE

item_id = xxxxx

缺点

需要创建多张表来描述规格参数之间的关系。

查询时需要复杂的sql语句查询。

规格参数数据量是商品信息的几十倍,数据量十分庞大,查询时效率很低。

商品参数变时需要改动多个表。

方案二

每一个商品对应一个规格参数的模板。

[

{

//规格组名称

"group": "主体",

// 组的规格项名称

"params": [

"品牌",

"型号",

"颜色",

"上市年份",

"上市月份"

]

},

{

"group": "网络",

"params": [

"4G",

"3G",

"2G"

]

}

]

添加商品时,根据规格参数模板生成表单,保存对应的规格参数的json格式。

[

{

//规格组名称

"group": "主体",

// 组的规格项名称

"params": [

{

"k": "品牌",

"v": "苹果(Apple)"

},

{

"k": "型号",

"v": "iPhone 6 A1589"

},

{

"k": "颜色",

"v": "白色"

},

{

"k": "上市年份",

"v": "2100"

},

{

"k": "上市月份",

"v": "12"

}

]

},

{

"group": "网络",

"params": [

{

"k": "4G",

"v": "支持"

},

{

"k": "3G",

"v": "支持"

},

{

"k": "2G",

"v": "支持"

}

]

}

]

特点

优点:

单表查询,不需要做多表管理。

如果要求新添加的商品规格项发生改变,只需要变更模板,之前的商品还是按照之前的格式存储。

缺点:

复杂的表单和json之间的转换。对js的编写要求很高。

python --商品规格--表结构设计的更多相关文章

  1. 商品表(spu)、规格表(sku)设计

    1. 先做一下专业术语解释:spu和sku 这里拿iphone6s举例,它身上有很多的属性和值, 比如: 毛重: 420.00 g 产地: 中国大陆 容量: 16G, 64G, 128G 颜色: 银, ...

  2. Day08_商品规格管理

    学于黑马和传智播客联合做的教学项目 感谢 黑马官网 传智播客官网 微信搜索"艺术行者",关注并回复关键词"乐优商城"获取视频和教程资料! b站在线视频 0.学习 ...

  3. 电商项目-商品表(spu)、规格表(sku)设计

    之前在工作中,需要实现商品规格功能,做了很长一段时间,现在回过头来整理下设计思路. sku,spu概念: SPU = Standard Product Unit (标准化产品单元),SPU是商品信息聚 ...

  4. TPshop的规格表设计原理机制

    TPshop商品规格比较简单, 数据库设计清晰, 先看上图购买商品时对应的选择, 不同规格有着不同的价格和不同的库存. 再看看后台对应的设置,手机例子 颜色:黑色 白色 金色 内存:32G 64G  ...

  5. ecshop 属性表(attribute)商品属性表(goods_attr)货品表(prduct) 商品数量的联系

    ecshop 属性表(attribute)商品属性表(goods_attr)货品表(prduct) 商品数量的联系 一个商城的商品属性存放在属性表(attribute)里 ,每个商品对应的属性在goo ...

  6. CMDB资产管理系统开发【day25】:表结构设计2

    表结构设计1详细注释代码 # _*_coding:utf-8_*_ __author__ = 'luoahong' from assets.myauth import UserProfile from ...

  7. tpshop商品属性表关系

    TPshop 里面的商品属性, 首先看看TPshop商品详情中的属性介绍, 纯展示给用户看的. 再来tpshop看看商品列表帅选页面的属性,可以根据属性帅选不同的商品 再来看看tpshop后台属性管理 ...

  8. 巨蟒django之CRM1 需求分析&&表结构设计&&注册登录验证

    1.需求分析 .项目 ()业务 ()权限的管理 .CRM customer relationship management 客户关系管理系统 .谁来使用CRM? 销售&&班主任& ...

  9. ofbiz数据库表结构设计(3)- 订单ORDER

    对于订单来说,主要的表就是ORDER_HEADER和ORDER_ITEM.ORDER_HEADER就是所谓的订单头,一条记录代表一条订单. ORDER_PAYMENT_PREFERENCE是订单的支付 ...

随机推荐

  1. IP路由实验之---Telnet远程登陆

    实验设备:一台华三路由器,一台PC 骤一,为路由器端口配置 IP 地址 <H3C>system-view #进入系统视图 [H3C] / #进入0/0端口 [H3C-Ethernet-/] ...

  2. 十七、 Observer 观察者设计模式

    设计: 代码清单: Observer public interface Observer { void update(NumberGenerator generator); } DigitObserv ...

  3. 保存一份自己常用的packjson

    这里是一份专门针对react的插件配置, 有: es5的转换器,有ie的promise垫片,有蚂蚁金服的anth,还有用于消息通信的pubsub订阅发布系统,虽然现在不用了.... 用于发请求的axi ...

  4. PHP开发——变量

    变量的概念 l  变量是临时存储数据的容器: l  变量是存储内存当中: l  我们现实中有很多数据:姓名.性别.年龄.学历等: l  在计算机中,用变量来代替一个一个的数据: l  我们可以把计算机 ...

  5. 3.Redis高级功能

    3.Redis高级功能3.1 慢查询分析3.1.1 慢查询的两个配置参数3.1.2 最佳实践3.1.3 单线程架构3.2 Redis Shell3.2.1 redis-cli 详解3.2.2 redi ...

  6. eclipse中将一个项目作为library导入另一个项目中

    1. github上搜索viewpagerIndicator: https://github.com/JakeWharton/ViewPagerIndicator2. 下载zip包,解压,eclips ...

  7. ORM初识和数据库操作

    ORM简介 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术.简单的说,ORM是通过使用描述对象和数据库之 ...

  8. CentOS 系统 git clone出错

    CentOS 操作系统 安装npm git clone 项目时出现类似如下错误: fatal: unable to access 'https://github.com/creationix/nvmg ...

  9. if语句和三元运算符的替换

    要求: 已经知道两个数,计算最大值 两个整数,比较大小 使用if还是三元 判断条件多,使用if 三元,必须有结果的, if 可以没有结果的*/public class IfElseDemo_1{ pu ...

  10. [网络流]Farm Tour(费用流

    Farm Tour 题目描述 When FJ's friends visit him on the farm, he likes to show them around. His farm compr ...