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

一、问题场景

对于一个论坛来说,现在有一个主题表,包括用户authorid、发表时间dateline等字段。
现在想要查询一些指定用户每个用户最近发表的两条记录,然后分页展示,这样该如何写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进行分页查询即可。

五、查询结果展示

图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值