如何为游戏排行榜设计对应的数据库 - V2EX
dream4ever

如何为游戏排行榜设计对应的数据库

  •  
  •   dream4ever May 18, 2021 2738 views
    This topic created in 1825 days ago, the information mentioned may be changed or developed.

    目前计划开发一系列面向小学生的答题类游戏,运行环境为微信 Web 端,用户通过公众号菜单进入游戏,后端通过每个用户在该公众号中的唯一 openid 对其进行标识。预计每个游戏最多会有几千个用户。

    对于每个学科,都会有一个专属的答题游戏,各学科的题目数量均有限,各游戏规则相同。

    用户在每个游戏中,每一轮都不重复地回答本学科下的所有题目,一旦答错一道题则本轮结束,并计算本轮答对的题目数量,然后开始下一轮。在每个游戏中,以各用户在该游戏中的历史最高分(即答对题目数量最多的那一轮)生成排行榜。这样的话,每个用户在每个游戏中能够拿到的最高分,就是该游戏对应学科的题目数量。

    数据库层面,我的设想是需要三张表:

    题目表:全是单项选择题,目前想的是保存题目的题干、选项、答案、分类这四个字段即可,之后有新的需求了再调整。

    用户表:用户的 openid 是必选项,其余像昵称、头像之类的都可以根据需求决定是否保留。

    排行榜表:每个游戏的排行榜,我能想到的必须要有的信息,是用户的 openid 、用户在该游戏中拿到的最高分。

    至于用户在每个游戏中拿到的最高分对应的排名,是否也需要保存到表中?

    每个游戏最多有几千名用户的话,假设一共有 4 个游戏,是否有必要为每个游戏的排行榜都单独建一张表?

    11 replies    2021-05-18 13:06:46 +08:00
    chogath
        1
    chogath  
       May 18, 2021   2
    redis zset
    oott123
        2
    oott123  
       May 18, 2021 via Android
    几千名用户你都不需要排行榜表,直接从用户表里 order by 一下就完了,建个 (游戏,最高分) 的降序索引,完事
    slert
        3
    slert  
       May 18, 2021
    应该还有个答题表吧。根据答题表实时算出排行榜也行。搞个缓存。
    要建排行榜表的话,每个游戏也没必要单独建表,用个字段区分吧。
    你这个访问量不大,怎么弄都好说。怎么简单怎么来。
    ch2
        4
    ch2  
       May 18, 2021
    几千个用户,直接一张表就搞定了
    shpkng
        5
    shpkng  
       May 18, 2021
    有些云服务会专门提供排行榜 api..
    Te11UA
        6
    Te11UA  
       May 18, 2021
    这个量级随便你用啥都行
    ThisDay
        7
    ThisDay  
       May 18, 2021
    几千个用户根本就不叫数据量,怎么简单怎么来,每次 orderby 也来得及
    kiracyan
        8
    kiracyan  
       May 18, 2021
    排行榜第一反应就是 redis
    AutumnVerse
        9
    AutumnVerse  
       May 18, 2021 via Android
    才几千用户哪需要什么设计,mysql order by 就行了,等有几千万用户需要实时排序的时候再来问吧
    joesonw
        10
    joesonw  
       May 18, 2021
    大型手游都是 redis zset
    bsg1992
        11
    bsg1992  
       May 18, 2021
    几千个用户 用啥设计啊 数据库 order by
    About     Help     Advertise     Blog     API     FAQ     Solana     2547 Online   Highest 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 43ms UTC 16:04 PVG 00:04 LAX 09:04 JFK 12:04
    Do have faith in what you're doing.
    ubao msn 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