PHP 和 MySQL 上的好友系统
Friendsystem on PHP and MySQL
此刻我卡在我的代码上了。
我想显示接受个朋友的名字。
我有两个表:
Users
[id, useruniqueid, username]
Friends
[id, user_a, user_b, status]
(状态可以是requested, pending or accepted)
例如:
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_* 已被弃用
如果您在一个查询中完成所有操作(使用 join
),您可以使用 MySQL 的 distinct
运算符来仅 return 每个查询的一个实例用户名。
尝试使用如下所示的查询。加入使用 case 语句,因此它通过 user_a 或 user_b 加入 Friends table,具体取决于哪一个是 而不是 $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”。
此刻我卡在我的代码上了。
我想显示接受个朋友的名字。
我有两个表:
Users
[id, useruniqueid, username]
Friends
[id, user_a, user_b, status]
(状态可以是requested, pending or accepted)
例如:
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_* 已被弃用
如果您在一个查询中完成所有操作(使用 join
),您可以使用 MySQL 的 distinct
运算符来仅 return 每个查询的一个实例用户名。
尝试使用如下所示的查询。加入使用 case 语句,因此它通过 user_a 或 user_b 加入 Friends table,具体取决于哪一个是 而不是 $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”。