V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
onefouroo
V2EX  ›  Flask

初学 Flask 有个小问题请教下小伙伴

  •  
  •   onefouroo · 2017-07-28 13:37:58 +08:00 · 2835 次点击
    这是一个创建于 2680 天前的主题,其中的信息可能已经有所发展或是发生改变。

    商品的模型如何设计? 如 iphone7 它有容量(16G,32G,64G) 颜色(黑色,白色,金色) 等属性, 商品与属性如何关联? 某些商品的属性又仅有颜色,没有容量. 初学中,老司机们能否提供一个思路?

    7 条回复    2017-07-28 14:55:45 +08:00
    xvx
        1
    xvx  
       2017-07-28 13:44:08 +08:00 via Android
    类似于博客的标签呀,做个标签表,多对多关系就 OK 了。
    PS:我也是初学。
    Panmax
        2
    Panmax  
       2017-07-28 13:45:47 +08:00
    SKU
    onefouroo
        3
    onefouroo  
    OP
       2017-07-28 14:16:59 +08:00
    @xvx 额,没有这么简单吧
    @Panmax 能详细点么
    ospider
        4
    ospider  
       2017-07-28 14:24:11 +08:00
    这个和 flask 没有什么关系吧,是你数据库设计的问题。一楼说的很好啊,只是你要加一些限制,某些 tag 是互斥的
    gclove
        5
    gclove  
       2017-07-28 14:24:19 +08:00
    同意 sku , @onefouroo 你先百度一下, 这是一个电商属于.
    就是说, 所有规格都相同的产品才有相同的 sku.

    你可以设计成这个样子呀, 首先规格肯定要有一个表吧, 然后每个规格都要有自己的属性吧
    就是说, [颜色, 容量, 大小, 单位, 材质, 功率, 体积...] 这些都可以自定义
    gclove
        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')]
    onefouroo
        7
    onefouroo  
    OP
       2017-07-28 14:55:45 +08:00
    @ospider 确实是算数据库设计的问题,只是现在在学 flask 遇到
    @gclove 我是这样搞得,一个商品总表, 然后多对多到真实商品表,这个真实商品表就是一行一个商品.列表显示商品总表,放入购物车的是真实商品. 这样做到是跑通了,只是感觉太二了.所以请教一下普遍做法.
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5478 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 07:43 · PVG 15:43 · LAX 23:43 · JFK 02:43
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.