题51:
根据下表编写一条 SQL 查询来找出在同一天阅读至少两篇文章的人,结果按照 id 升序排序。
其中:该表无主键,可能会存在重复行。该表的每一行都表示某人在某天浏览了某位作者的某篇文章。 请注意,同一人的 author_id 和 viewer_id 是相同的。
解题思路:
(1)首先题目要求是同一天,因此利用group by 根据时间聚合记录;
(2)然后根据至少阅读两篇文章的人的题目要求,还需要根据人来聚合计算每个人阅读的文章数,因此在group by 基础上使用having过滤条件;
(3)最后将结果按照 id 升序排序。
select distinct viewer_id as id
from Views
group by view_date,viewer_id
having count(distinct article_id) >=2
order by id ;