如何为游戏排行榜设计对应的数据库 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
dream4ever
V2EX    数据库

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

  •  
  •   dream4ever 2021 年 5 月 18 日 2591 次点击
    这是一个创建于 1717 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

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

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

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

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

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

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

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

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

    11 条回复    2021-05-18 13:06:46 +08:00
    chogath
        1
    chogath  
       2021 年 5 月 18 日   2
    redis zset
    oott123
        2
    oott123  
       2021 年 5 月 18 日 via Android
    几千名用户你都不需要排行榜表,直接从用户表里 order by 一下就完了,建个 (游戏,最高分) 的降序索引,完事
    slert
        3
    slert  
       2021 年 5 月 18 日
    应该还有个答题表吧。根据答题表实时算出排行榜也行。搞个缓存。
    要建排行榜表的话,每个游戏也没必要单独建表,用个字段区分吧。
    你这个访问量不大,怎么弄都好说。怎么简单怎么来。
    ch2
        4
    ch2  
       2021 年 5 月 18 日
    几千个用户,直接一张表就搞定了
    shpkng
        5
    shpkng  
       2021 年 5 月 18 日
    有些云服务会专门提供排行榜 api..
    Te11UA
        6
    Te11UA  
       2021 年 5 月 18 日
    这个量级随便你用啥都行
    ThisDay
        7
    ThisDay  
       2021 年 5 月 18 日
    几千个用户根本就不叫数据量,怎么简单怎么来,每次 orderby 也来得及
    kiracyan
        8
    kiracyan  
       2021 年 5 月 18 日
    排行榜第一反应就是 redis
    AutumnVerse
        9
    AutumnVerse  
       2021 年 5 月 18 日 via Android
    才几千用户哪需要什么设计,mysql order by 就行了,等有几千万用户需要实时排序的时候再来问吧
    joesonw
        10
    joesonw  
       2021 年 5 月 18 日
    大型手游都是 redis zset
    bsg1992
        11
    bsg1992  
       2021 年 5 月 18 日
    几千个用户 用啥设计啊 数据库 order by
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     5306 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 24ms UTC 08:47 PVG 16:47 LAX 00:47 JFK 03:47
    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