一、问题场景
对于一个论坛来说,现在有一个主题表,包括用户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语句解析:
- 先查询出这些用户所有的记录,生成一个临时表 a
-
然后子查询中的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即可。
- 以上两步查出了这些特定用户每个用户最新发表的两条记录,然后记为A,通过limit进行分页查询即可。
五、查询结果展示