商品规格表结构设计

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

规格组

|-规格项:规格值

|-规格项:规格值

规格组

|-规格项:规格值

|-规格项:规格值

同一类商品的规格相同。

方案一

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

表设计

商品表: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. Codeforces Round #437 E. Buy Low Sell High

    题意:买卖股票,给你n个数,你可以选择买进或者卖出或者什么都不做,问你最后获得的最大收益是多少. Examples Input 910 5 4 7 9 12 6 2 10 Output 20 Inpu ...

  2. JS 操作样式 style

    1. 任何支持 style 特性的 HTML 元素在 JavaScript 中都对应着有一个 style 属性,指向一个 CSSStyleDeclaration 的一个实例对象,包含该元素的内嵌sty ...

  3. 伪类+js实现CSS3 media queries跨界准确判断

    @media screen and (min-width: 45em) { body:after{ content:"宽屏" } } var content = window.ge ...

  4. [Java核心技术笔记]并发

    Runnable Runnable接口是函数式接口 //Runnable接口 public interface Runnable { void run(); } //用lambda表达式创建实例 Ru ...

  5. thinkphp5中使用excel导出数据表格(包涵图片)

    首先使用composer require phpoffice/phpexcel下载安装phpexcel包. 将包放入extend下面. 不附加图片的导出 /** * 导出excel(不带图片) * @ ...

  6. ubuntu6.4系统安装JIRA-7.8

    一.系统环境: system version:ubuntu6.4 openjdk version  (java版本) :1.8.0_191  mysql version:14.14 jira vers ...

  7. adc指令

    adc是带进位加法指令,它利用了CF位上记录的进位值. 指令格式: adc 操作对象1,操作对象2 功能:操作对象1 = 操作对象1 + 操作对象2 + CF 例如指令 adc  ax,bx实现的功能 ...

  8. Admin注册和路由分发详解

    Admin注册和路由分发详解 1.启动 #autodiscover_modules('admin', register_to=site) 2.注册 1.单例对象 admin.site = AdminS ...

  9. BZOJ1880或洛谷2149 [SDOI2009]Elaxia的路线

    BZOJ原题链接 洛谷原题链接 显然最长公共路径是最短路上的一条链. 我们可以把最短路经过的边看成有向边,那么组成的图就是一张\(DAG\),这样题目要求的即是两张\(DAG\)重合部分中的最长链. ...

  10. spring mvc mybatis shiro构建cms系统ios android

    开发语言: java.ios.android 部署平台: linux.window jdk版本:JDK1.7以上版本 开发工具: eclipse.idea等 服务器中间件:Tomcat 6.7.Jbo ...