数据库小白求教 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
xhuuanniqege
V2EX    问与答

数据库小白求教

  •  
  •   xhuuanniqege 2015-11-13 17:40:34 +08:00 2691 次点击
    这是一个创建于 3622 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我正在练习做一个 APP,现在需要在服务器保存用户信息。我新建了一个 USERINFO 的表,表中有一个名为 ORDER 的列,表示该用户的历史订单号。可是一个用户有很多个订单,这样的话,对于每个用户该 ORDER 属性下面就应该保存很多个订单号。这个好像没法实现。如果为每一个用户在创建一个 ORDER 的表,那么这个表只有两列,用户 ID 和订单号,似乎很浪费啊。请问在这种情况下我该怎么组织数据库?

    15 条回复    2015-11-14 19:25:20 +08:00
    chenzhuo
        1
    chenzhuo  
       2015-11-13 17:43:06 +08:00
    应该创建一个订单表 Order,订单表里有一个字段是记录用户 id 的。这样根据用户 id 就能查到每个用户的所有订单了。
    xhuuanniqege
        2
    xhuuanniqege  
    OP
       2015-11-13 18:34:56 +08:00
    @chenzhuo 这样的话,每次要获得某个 ID 用户所有订单,就要用 select * from Order where user_id = xxx ,会不会效率不高?
    oott123
        3
    oott123  
       2015-11-13 18:37:59 +08:00
    @xhuuanniqege 不会。给 user_id 加个索引。
    heaton_nobu
        4
    heaton_nobu  
       2015-11-13 18:47:22 +08:00
    关系型数据库就是要建子表
    guoer
        5
    guoer  
       2015-11-13 18:49:11 +08:00
    1 楼正解

    最好不要用 order 因为是关键字
    xhuuanniqege
        6
    xhuuanniqege  
    OP
       2015-11-13 19:15:45 +08:00
    @oott123
    @heaton_nobu
    @guoer
    多谢建议,我准备看看有关索引和关系型数据库的内容
    yjxjn
        7
    yjxjn  
       2015-11-13 19:18:23 +08:00 via iPhone
    主 userid 为 primary key ,然后子表写订单号为 pri key , userid 为 f key ,这样的话最后做表关联不就行了么,这种肯定得做两个表,一个主表,一个附表,这样的话,效率很高,单独检索订单号的时候,查某人的订单的时候,等等,不信你可以想想。
    xhuuanniqege
        8
    xhuuanniqege  
    OP
       2015-11-13 19:39:02 +08:00
    @yjxjn 嗯,我现在正打算这么做。另外在请教下,现在一个订单是由多个商品组成的,我是不是应该在建个 order_item 表
    table order_item (
    order_id int(10),
    product_id int(10),
    quantity
    )
    ETiV
        9
    ETiV  
       2015-11-13 20:43:35 +08:00
    LZ 听说过 Facebook Parse, 或者国内的 LeanCloud 没

    BaaS 服务, 专注解决后端问题, 直接调用他们的客户端 SDK 就行了. 简单需求几乎不需要写服务端逻辑.
    shiny
        10
    shiny  
       2015-11-13 20:50:19 +08:00
    一般 生产环境的情况是:哪有那么多订单啊。你想多了。
    yjxjn
        11
    yjxjn  
       2015-11-13 21:01:17 +08:00
    @xhuuanniqege 对,每个商品有一个单独的 ID ,很多商品 ID 属于同一个订单 ID ,还得来个表, productList 定义好商品名称,编号(算是二维码那种的),入库时间,库存等等,然后相互关联就可以了。
    yjxjn
        12
    yjxjn  
       2015-11-13 21:02:23 +08:00
    这种东西别想着几张表就可以完事,我们的系统,总共 100 多张表。索引建立好,相互关联的写就行了
    GKLuke
        13
    GKLuke  
       2015-11-14 08:29:37 +08:00
    搞数据库之前先了解一下 3NF ( BCNF )
    xhuuanniqege
        14
    xhuuanniqege  
    OP
       2015-11-14 19:23:14 +08:00 via Android
    @yjxjn 原来是这样,感谢!
    xhuuanniqege
        15
    xhuuanniqege  
    OP
       2015-11-14 19:25:20 +08:00 via Android
    @GKLuke 谢谢,目前正在边学边看
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     945 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 22ms UTC 20:13 PVG 04:13 LAX 13:13 JFK 16:13
    Do have faith in what you're doing.
    ubao snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86