Zakładając, że nie jest możliwe, aby Użytkownik 1 zaprzyjaźnił się z Użytkownikiem 7 dwukrotnie (co oznacza, że nie może być wiersza z user_a = 1, user_b=7
i kolejny wiersz user_a = 7, user_b = 1
).
SELECT IF(user_a = 1 OR user_a = 2, user_b, user_a) friend
FROM friendship
WHERE (user_a = 1 OR user_a = 2) OR (user_b = 1 OR user_b = 2)
GROUP BY 1
HAVING COUNT(*) > 1