Friendsystem на PHP и MySQL

в этот момент я застрял на своем коде.

Я хочу отобразить имена принято друзья.

У меня есть две таблицы:

Users
[id, useruniqueid, username]

Friends
[id, user_a, user_b, status]

(статус может быть запрошен, в ожидании или принят)

Например:

Users:
1, 123, Kaan2106
2, 321, SOUser1
3, 456, SOU2
4, 654, Some4

Friends:
1, 123, 321, accepted
2, 321, 123, accepted
3, 456, 123, accepted
4, 123, 456, accepted
5, 654, 123, pending
6, 123, 654, requested

Я хочу отобразить имена моих друзей, например: «SOUser1» (потому что это принято)

И вот что я сделал:

<table>
<tr>
<td>Name</td>
</tr>
<?php
$getem = mysql_query("SELECT * FROM Friends WHERE (`status` = 'accepted') AND (`user_a` = '$UserUUID' OR `user_b` = '$UserUUID') LIMIT 10");
while($row = mysql_fetch_assoc($getem)) {
$friendsql = mysql_query("SELECT * FROM Users WHERE useruniqueid = '" . ($row['user_a'] == $UserUUID ? $row['user_b'] : $row['user_a']) . "'");
$friendrow = mysql_fetch_assoc($friendsql);
?>
<tr>
<td class="friend-name">
<?php echo $friendrow['username']; ?>
</td>
</tr>
<?php } ?>
</table>

И мой вывод такой SOUser1, SOUser1, SOU2, SOU2
(нежелательные двойники)

Ожидаемый результат должен быть таким SOUser1, SOU2
(без двойников)

Я знаю, что mysql_ * устарела

0

Решение

Если вы делаете все это в одном запросе (с join), вы можете использовать MySQL distinct Оператор возвращает только один экземпляр имени каждого пользователя.

Попробуйте использовать запрос, подобный приведенному ниже. В соединении используется оператор case, поэтому он присоединяется к таблице Friends с помощью user_a или user_b, в зависимости от того, какой из них не $UserUUID,

select distinct
u.username
from
Friends f
join Users u
on (
u.useruniqueid = case
when f.user_a='{$UserUUID}' then f.user_b
else f.user_a
end
)
where
(f.user_a = '{$UserUUID}' or f.user_b = '{$UserUUID}')
and f.status='accepted'

Увидеть это в SQL Fiddle, с $UserUUID устанавливается на «123».

1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]