+----------------+---------+
|Column Name |Type|+----------------+---------+
| requester_id | int || accepter_id | int || accept_date | date |+----------------+---------+
(requester_id, accepter_id) is the primarykey (combination of columns withuniquevalues) for this table.
This tablecontains the ID of the user who sent the request, the ID of the user who received the request, and the date when the request was accepted.
Write a solution to find the people who have the most friends and the most friends number.
The test cases are generated so that only one person has the most friends.
Input:
RequestAccepted table:+--------------+-------------+-------------+| 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|+--------------+-------------+-------------+Output:
+----+-----+| id | num |+----+-----+|3|3|+----+-----+Explanation:
The person with id 3is a friend of people 1,2, and 4, so he has three friends in total, which is the most number than any others.
Follow up: In the real world, multiple people could have the same most
number of friends. Could you find all these people in this case?
A friendship is bidirectional, so both requester and accepter become friends. We can count the number of unique friends for each user by combining both columns and aggregating.
SELECT user_id, COUNT(DISTINCT friend_id) AS num
FROM (
SELECT requester_id AS user_id, accepter_id AS friend_id FROM RequestAccepted
UNIONALLSELECT accepter_id, requester_id FROM RequestAccepted
) t
GROUPBY user_id
ORDERBY num DESCLIMIT1;
1
2
3
4
5
6
7
8
9
SELECT user_id, COUNT(DISTINCT friend_id) AS num
FROM (
SELECT requester_id AS user_id, accepter_id AS friend_id FROM RequestAccepted
UNIONALLSELECT accepter_id, requester_id FROM RequestAccepted
) t
GROUPBY user_id
ORDERBY num DESCLIMIT1;