0

此刻我被困在我的代码上。

我想显示接受的朋友的名字。

我有两张桌子:

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_* 已被弃用

4

1 回答 1

1

如果您在一个查询中完成所有操作(使用 a join),则可以使用 MySQL 的distinct运算符仅返回每个用户名的一个实例。

尝试使用如下查询。连接使用 case 语句,以便通过 user_a 或 user_b 连接 Friends 表,具体取决于哪个不是$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”。

于 2017-11-16T17:34:37.663 回答