2013-04-18 19 views
4

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; 
+0

考虑采取的朋友列到另一个表并存储每个朋友一个新行,不在阵列中。也不要在每次登录时插入新行,但更新当前时间戳值。你也可以使用'INSERT ....对重复密钥更新在线= NOW()' –

+0

嗯,我想到了这一点。要创建另一个表,当他们去离线,你不会得到你希望他们离开后的结果只使用ID,USER_ID和friends_id .. – AlwaysConfused

回答

2
<?php 
    $friends = array(1,5,16); // Array of friends 
    $friendIDs = implode(',', $friends); // Turns array into string for SQL select statement 

    // Gets only friends info from DB 
    $sql = " 
     SELECT date, ip, name, user_id 
     FROM users_online 
     WHERE user_id IN (".$friendIDs.")"; 
?> 
+0

虽然没有从user_online表中删除的条目... –

0

你应该考虑改变数据库模式。这里有一个例子:

USER表:

id | name | current_session_id 

USER_FRIEND_USER表(包含朋友说,用户已添加):

user_id | friend_user_id 

会话表:

id | user_id | created_at | expires_at 

SQL查询来获取与ID用户的好友列表“?”:

SELECT u.id, u.name FROM USER u 
    INNER JOIN USER_FRIEND_USER ufu ON (ufu.friend_user_id = u.id) 
    INNER JOIN SESSION s ON (s.id = u.current_session_id) 
    WHERE ufu.user_id = ? AND s.expires_at >= NOW(); 

这里的SQL小提琴链接:http://sqlfiddle.com/#!2/34f83/1/0

2

整理出来的家伙!谢谢你的帮助!

//Selecting an array from db 
$DB = mysql_query("SELECT friend_array FROM users_online WHERE user_id=".$userid); 
    while($row=mysql_fetch_assoc($DB)) 
    { 
    $friend_array = $row['friend_array']; 
    $friends = array($friend_array); // Array of friends 
    $friendIDs = implode(',', $friends); 
    } 
// Counting all the online friends: 

list($totalOnline) = mysql_fetch_array(mysql_query(" 
     SELECT COUNT(*) 
     FROM users_online 
     WHERE user_id IN (".$friendIDs.")")); 


// Outputting the number as plain text: 
echo $totalOnline; 

输出为1个用户在线,因为我用2级的浏览器和在users_online表被创建2行编号为1和2..And ID loged在1具有在阵列3周的朋友(2,5,16) ,并且id为2的用户拥有(1,3)。因此,在每个浏览器中,输出为1..Uray!我希望这个问题在您使用更新功能上mSQL的表someone..Btw林,如果用户注销,我只是删除行users_online表:)