V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
messyidea
V2EX  ›  问与答

社交网站的动态是怎么实现的?

  •  
  •   messyidea · 2015-05-30 21:02:07 +08:00 · 2183 次点击
    这是一个创建于 3494 天前的主题,其中的信息可能已经有所发展或是发生改变。
    动态里面有不同类型的数据,比如相册更新,说说,博文,推荐等等。
    这些东西都放在数据库中不同的表中。
    每种数据都有一个共同的字段是时间。
    怎么才能够很好地按照时间的顺序把这些不同格式的东西取出来?(好友动态要求分页)
    8 条回复    2015-05-30 21:37:31 +08:00
    lichao
        1
    lichao  
       2015-05-30 21:13:37 +08:00   ❤️ 1
    加个 timeline 表呗
    wy315700
        2
    wy315700  
       2015-05-30 21:16:31 +08:00   ❤️ 1
    nosql
    messyidea
        3
    messyidea  
    OP
       2015-05-30 21:18:33 +08:00
    @lichao timeline表是不是就id,type,time三个字段就可以了?要取到数据是不是要再查数据库n遍?会不会效率不高?
    messyidea
        4
    messyidea  
    OP
       2015-05-30 21:22:14 +08:00
    @wy315700 能不能具体说说?或者有没有什么相关的网页?我只了解一些redis,但是还没有使用过,不知道怎么把它应用在这种环境。 而且主要是那几张表已经定好了,规模还小的时候感觉用不上nosql
    wy315700
        5
    wy315700  
       2015-05-30 21:28:04 +08:00   ❤️ 1
    @messyidea
    redis的话,每用户一个list表示时间轴,然后根据ID去取
    lichao
        6
    lichao  
       2015-05-30 21:33:24 +08:00   ❤️ 1
    如果是 timeline 表的话,可以有个信息摘要字段啊,这样就不存在 [查数据库N遍] 的问题了。
    适当允许一些冗余数据,向性能妥协。
    messyidea
        7
    messyidea  
    OP
       2015-05-30 21:35:38 +08:00
    @wy315700 那获取这些数据的时候,每个数据都要根据ID去查一遍数据库吗?(现在其它数据是放在mysql里面的)
    messyidea
        8
    messyidea  
    OP
       2015-05-30 21:37:31 +08:00
    @lichao 恩,我明白了,谢谢~
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5515 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 32ms · UTC 08:26 · PVG 16:26 · LAX 00:26 · JFK 03:26
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.