本文主要是介绍[高频sql第602题],谁拥有最多的好友,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
编写解决方案,找出拥有最多的好友的人和他拥有的好友数目。
生成的测试用例保证拥有最多好友数目的只有 1 个人。
查询结果格式如下例所示。
示例 1:
输入: RequestAccepted 表: +--------------+-------------+-------------+ | requester_id | accepter_id | accept_date | +--------------+-------------+-------------+ | 1 | 2 | 2016/06/03 | | 1 | 3 | 2016/06/08 | | 2 | 3 | 2016/06/08 | | 3 | 4 | 2016/06/09 | +--------------+-------------+-------------+ 输出: +----+-----+ | id | num | +----+-----+ | 3 | 3 | +----+-----+ 解释: 编号为 3 的人是编号为 1 ,2 和 4 的人的好友,所以他总共有 3 个好友,比其他人都多。
这道题其实很简单,只是需要换种思路,我先上代码后上结论
select
id,
count(*) as num
from(select requester_id as id from RequestAcceptedunion all select accepter_id from RequestAccepted
)as a
group by id
order by num desc limit 1
下面是对这段代码的逐步分析:
1. 子查询:
获取所有请求者和接收者的id,并罗列到一起
2. 分组:
- `GROUP BY id`:按照用户ID进行分组,看每个id有多少请求
3. 排序和限制:
- `ORDER BY num DESC`:按照好友数量降序排序,这样拥有最多好友的用户会排在最前面。
- `LIMIT 1`:限制结果只返回顶部的一条记录,即拥有最多好友的用户。
这篇关于[高频sql第602题],谁拥有最多的好友的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!