OK,所以我有headech从到处搜寻,如何解决这个problem..Im试图显示在线用户,但并不是所有的用户,只有谁是在你的好友列表..Mysql的在线好友显示
所以我有一个名为users_online的表,当用户登录在我的网站在该表中自动创建1行与日期,IP,名称,user_id和friend_array(其中所有用户的朋友保留)
因此,例如我登录我的网站和行是在users_online表中创建的。我想在网上看到的只是我的朋友,这些朋友都存储在friend_array列(1,5,16,5(那朋友ID号))。我如何可以从friends_array科拉姆数据,看看这些ID的一个的记录目前,这意味着这些id中哪些存在于user_online表中并显示在我的配置文件中?
我希望不是混乱的问题...
那么这就是我的code..all专卖店在online.php文件:
// Checking wheter the visitor is already marked as being online:
$inDB = mysql_query("SELECT user_id FROM users_online WHERE user_id=".$userid);
if(!mysql_num_rows($inDB))
{
// Selects some data required to insert into users_online table from users table
$DB = mysql_query("SELECT img,fname,friend_array FROM users WHERE user_id=".$userid);
while($row=mysql_fetch_assoc($DB))
{
$img = $row['img'];
$fname = $row['fname'];
$farray = $row['friend_array'];
}
mysql_query(" INSERT INTO users_online (user_id,ip,img,fname,friend_array)
VALUES(".$userid.",'".$intIp."','".$img."','".$fname."','".$farray."')");
}
else
{
// If the visitor is already online, just update the dt value of the row:
mysql_query("UPDATE users_online SET dt=NOW() WHERE user_id=".$userid);
}
// Counting all the online visitors:
// Thats where i need to work out with friend array..
// I need to display all online friends only
list($totalOnline) = mysql_fetch_array(mysql_query("SELECT COUNT(*) FROM users_online"));
// Outputting the number as plain text:
echo $totalOnline;
考虑采取的朋友列到另一个表并存储每个朋友一个新行,不在阵列中。也不要在每次登录时插入新行,但更新当前时间戳值。你也可以使用'INSERT ....对重复密钥更新在线= NOW()' –
嗯,我想到了这一点。要创建另一个表,当他们去离线,你不会得到你希望他们离开后的结果只使用ID,USER_ID和friends_id .. – AlwaysConfused