0

我正在创建一个社交网络。我想让一个用户能够订阅人们。理论上,当用户单击订阅按钮时,PHP 会将该用户的 ID 添加到 MYSQL 列表中“订阅”列下的数组中。现在,我想要一个新闻提要风格的主页。我想知道,如果我通过 PHP 提取“订阅”数据,我怎么能只显示用户订阅的人的帖子(也在 MYSQL 表中)?

4

2 回答 2

1

使用 UNION 组合来自不同表的所有帖子,然后使用“IN”子句根据当前用户 ID 获取您想要关注的所有用户 ID:

例子:

$userFavs = "SELECT userID FROM favs WHERE followerID = '#loggedinUserID#'"

mysql_query("SELECT 'wall' as type, body, date FROM wall WHERE userID IN ($userFavs) 
UNION
SELECT 'photo' as type, caption, date FROM photos WHERE userID IN ($userFavs) UNION... etc
ORDER BY date DESC");

如果您通过 mysql_fetch_array() 运行查询,它将返回如下内容:

Array => {
[0] => { type = "wall", body = "This is a wall update", date = "1234567890" },
[1] => { type = "photo", caption = "Us at the beach", date = "..." },
...
}

每次调用“UNION”时,您需要确保每个 SELECT 语句中的列数相同,否则它将不起作用。您可以 /fake/ 列,就像我对上面的列所做的那样type

于 2012-04-12T01:04:45.147 回答
0

我认为您正在寻找一种在数据库中序列化数组的方法。也可能有帮助!

于 2012-04-12T01:02:56.813 回答