sql查询最近发表的记录,按照用户分组分页

一、问题场景

对于一个论坛来说,现在有一个主题表,包括用户authorid、发表时间dateline等字段。
现在想要查询一些指定用户每个用户最近发表的两条记录,然后分页展示,这样该如何写sql语句呢?

二、sql语句截图

《sql查询最近发表的记录,按照用户分组分页》

三、sql:

SELECT  A.*
FROM (
SELECT a.authorid, a.tid,a.subject,a.dateline,(SELECT COUNT(*)+1 FROM pre_forum_thread b 
             where b.authorid=a.authorid and b.dateline>a.dateline 
              ) as group_id

FROM pre_forum_thread a
where  a.authorid in (10,12,14,1095,1326,1626)
) A
WHERE A.group_id<3
ORDER BY A.dateline DESC
LIMIT 0,6

四、sql语句解析:

  1. 先查询出这些用户所有的记录,生成一个临时表 a
  2. 然后子查询中的group_id是如何生成的呢?

       (1)a表与b表联合查询,其实是自己与自己联合b.authorid=a.authorid,然后a表数据每条记录与b表所有记录进行比较dateline,查出a表每条明细之后发表了多少个,记为group_id。
       (2)最新时间之后发表的记录个数group_id是0,倒数第二个时间之后发表的记录个数group_id是1,依次类推。。。
       (3)发现,如果想要查询到最新发表的两条记录,那么只要group_id<2即可。
       (4)此处select count(*)+1,那么group_id<3即可。
  3. 以上两步查出了这些特定用户每个用户最新发表的两条记录,然后记为A,通过limit进行分页查询即可。

五、查询结果展示

《sql查询最近发表的记录,按照用户分组分页》

    原文作者:繁星落眼眶
    原文地址: https://segmentfault.com/a/1190000014190541
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞