商品的模型如何设计? 如 iphone7 它有容量(16G,32G,64G) 颜色(黑色,白色,金色) 等属性, 商品与属性如何关联? 某些商品的属性又仅有颜色,没有容量. 初学中,老司机们能否提供一个思路?
1
xvx 2017-07-28 13:44:08 +08:00 via Android
类似于博客的标签呀,做个标签表,多对多关系就 OK 了。
PS:我也是初学。 |
2
Panmax 2017-07-28 13:45:47 +08:00
SKU
|
4
ospider 2017-07-28 14:24:11 +08:00
这个和 flask 没有什么关系吧,是你数据库设计的问题。一楼说的很好啊,只是你要加一些限制,某些 tag 是互斥的
|
5
gclove 2017-07-28 14:24:19 +08:00
同意 sku , @onefouroo 你先百度一下, 这是一个电商属于.
就是说, 所有规格都相同的产品才有相同的 sku. 你可以设计成这个样子呀, 首先规格肯定要有一个表吧, 然后每个规格都要有自己的属性吧 就是说, [颜色, 容量, 大小, 单位, 材质, 功率, 体积...] 这些都可以自定义 |
6
gclove 2017-07-28 14:31:21 +08:00
@onefouroo @Panmax @xvx
给你一段 python2.7 的代码 from itertools import product print list(product(['Red','Black','White'], ['64G','128G'], ['USB','Type-C'])) 求笛卡尔乘积正好可以用来计算, 可以生成多少个 sku, 不过一般不用实际的属性表示, 都是 ID [颜色, 容量, 接口类型] 这三个产品属性. 可以组成这么多种产品 [('Red', '64G', 'USB'), ('Red', '64G', 'Type-C'), ('Red', '128G', 'USB'), ('Red', '128G', 'Type-C'), ('Black', '64G', 'USB'), ('Black', '64G', 'Type-C'), ('Black', '128G', 'USB'), ('Black', '128G', 'Type-C'), ('White', '64G', 'USB'), ('White', '64G', 'Type-C'), ('White', '128G', 'USB'), ('White', '128G', 'Type-C')] |