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

文章列表怎么高效的实现类似于 Feeds 的已读未读效果?

  •  
  •   cxh116 · 2017-11-02 21:20:45 +08:00 · 1412 次点击
    这是一个创建于 2581 天前的主题,其中的信息可能已经有所发展或是发生改变。

    类似 RSS 阅读器的效果,文章被阅读后不再在列表显示.

    目前想到比较挫的实现.
    增加一个中间表,记录文章 id 和用户 id.阅读后往中间表插入一条记录.
    查询文章列表时,排除此用户在中间表存在的文章 ID .
    这样实现最简单,用了子查询,感觉后面性能是个大问题.

    另外一种就是看网上说的,记录最近阅读的最大和最小的 id,查询时排除最大和最小的.
    这样做有两个问题.

    1. 如果文章不是按 id 来排序,那么就会失效.比如按点击数来排.
    2. 如果有多个分类,有时需要按单个分类查看,有时聚合在一起看(最新文章),这样也会失效.

    请问这个有更高效的实现方式吗? 先谢谢了

    第 1 条附言  ·  2017-11-02 21:57:25 +08:00
    目前找到的,用 外连接 把 user_id 写在 on 过滤里面应该是最简单的方式吧.

    https://stackoverflow.com/questions/31553462/database-design-for-getting-unread-article-in-mysql-over-100m-row-table
    4 条回复    2017-11-03 07:37:44 +08:00
    cxh116
        1
    cxh116  
    OP
       2017-11-02 21:42:13 +08:00
    找到一个用中间表 右外连接 文章表的实现方式,不用子查询,性能应该会好点.

    https://stackoverflow.com/questions/14200105/selecting-unread-documents-in-postgresql-joins
    carlclone
        2
    carlclone  
       2017-11-02 21:44:18 +08:00 via Android
    redis....集合
    nfroot
        3
    nfroot  
       2017-11-02 22:47:09 +08:00
    这个帖子下面也有 XXX 个会员查看过这个帖子……

    想想如果是中间表,这个表会超级大……
    cxh116
        4
    cxh116  
    OP
       2017-11-03 07:37:44 +08:00 via Android
    @nfroot 是会超级大,所以 append 的链接提到一个按 user id 分表的方案。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1051 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 20:13 · PVG 04:13 · LAX 12:13 · JFK 15:13
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.