python --商品规格--表结构设计
商品规格表结构设计
商品规格包括规格组合、规格项,规格项为规格组的成员。
规格组
|-规格项:规格值
|-规格项:规格值
规格组
|-规格项:规格值
|-规格项:规格值
同一类商品的规格相同。
方案一
使用多个表存储商品规格。在已有的商品分类表和商品表的基础上,增加商品规格分组表、商品规格项表、商品规格值表。
表设计
商品表: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 --商品规格--表结构设计的更多相关文章
- 商品表(spu)、规格表(sku)设计
1. 先做一下专业术语解释:spu和sku 这里拿iphone6s举例,它身上有很多的属性和值, 比如: 毛重: 420.00 g 产地: 中国大陆 容量: 16G, 64G, 128G 颜色: 银, ...
- Day08_商品规格管理
学于黑马和传智播客联合做的教学项目 感谢 黑马官网 传智播客官网 微信搜索"艺术行者",关注并回复关键词"乐优商城"获取视频和教程资料! b站在线视频 0.学习 ...
- 电商项目-商品表(spu)、规格表(sku)设计
之前在工作中,需要实现商品规格功能,做了很长一段时间,现在回过头来整理下设计思路. sku,spu概念: SPU = Standard Product Unit (标准化产品单元),SPU是商品信息聚 ...
- TPshop的规格表设计原理机制
TPshop商品规格比较简单, 数据库设计清晰, 先看上图购买商品时对应的选择, 不同规格有着不同的价格和不同的库存. 再看看后台对应的设置,手机例子 颜色:黑色 白色 金色 内存:32G 64G ...
- ecshop 属性表(attribute)商品属性表(goods_attr)货品表(prduct) 商品数量的联系
ecshop 属性表(attribute)商品属性表(goods_attr)货品表(prduct) 商品数量的联系 一个商城的商品属性存放在属性表(attribute)里 ,每个商品对应的属性在goo ...
- CMDB资产管理系统开发【day25】:表结构设计2
表结构设计1详细注释代码 # _*_coding:utf-8_*_ __author__ = 'luoahong' from assets.myauth import UserProfile from ...
- tpshop商品属性表关系
TPshop 里面的商品属性, 首先看看TPshop商品详情中的属性介绍, 纯展示给用户看的. 再来tpshop看看商品列表帅选页面的属性,可以根据属性帅选不同的商品 再来看看tpshop后台属性管理 ...
- 巨蟒django之CRM1 需求分析&&表结构设计&&注册登录验证
1.需求分析 .项目 ()业务 ()权限的管理 .CRM customer relationship management 客户关系管理系统 .谁来使用CRM? 销售&&班主任& ...
- ofbiz数据库表结构设计(3)- 订单ORDER
对于订单来说,主要的表就是ORDER_HEADER和ORDER_ITEM.ORDER_HEADER就是所谓的订单头,一条记录代表一条订单. ORDER_PAYMENT_PREFERENCE是订单的支付 ...
随机推荐
- logrotate-日志切割示例
logrotate是linux系统自带的工具,它可以自动对日志进行截断(或轮循).压缩以及删除旧的日志文件. 1)配置文件示例# cat /wls/wls81/bin/weblogic/wls/app ...
- DJango 基础 (1)
django基础 知识点: 基本认知 工具准备 新建项目 目录及文件说明 开发服务器 创建视图函数 新建应用(app) 1.基本认知 Django是用Python开发的一个免费开源的Web框架,可以用 ...
- python--第十三天总结(html ,css 语法)
概述 HTML是英文Hyper Text Mark-up Language(超文本标记语言)的缩写,他是一种制作万维网页面标准语言(标记).相当于定义统一的一套规则,大家都来遵守他,这样就可以让浏览器 ...
- python的魔术方法
什么叫魔术方法: 在python中定义以双下划线开头,有一些python自定义的函数,并且以双下划线为结尾的函数叫做魔法函数 class Company(object): def __init__(s ...
- jQuery实现动态分割div—通过拖动分隔栏实现上下、左右动态改变左右、上下两个相邻div的大小
由jQuery实现上下.左右动态改变左右.上下两个div的大小,需要自己引入jquery1.8.0.min.js包 可用于页面布局. //============================ind ...
- 2017-2018-2 20165315 实验四《Android程序设计》实验报告
2017-2018-2 20165315 实验四<Android程序设计>实验报告 第24章:初识Android Android Studio项目的目录树 1 build:该目录包含了自动 ...
- Django contenttypes 应用
Django contenttypes 应用 什么是Django ContentTypes? Django ContentTypes是由Django框架提供的一个核心功能,它对当前项目中所有基于Dja ...
- centos free详解
CentOS 6及以前 $ free total used free shared buffers cached Mem: 4040360 4012200 28160 0 176628 3571348 ...
- MVC Log4Net 配置
1.引用log4net.dll 2.在项目根目录下增加log4.config文件 <?xml version="1.0"?> <configuration> ...
- GitHub上好的Java项目
1. java-design-patterns(Star:36k)Github地址:https://github.com/iluwatar/java-design-patterns 介绍:设计模式是形 ...