我有以下表格:
post (id, title, content) etc
author (id, username) etc
author_vote (post_id, author_id, value)
值是可以是 1 或 -1 的 tiny_int。
我想统计每个帖子的正面和负面投票数:
$posts = sql_select($link, "SELECT post.*, author.username
FROM post, author
AND author.id = post.author_id");
为什么下面的代码不起作用?
array_walk($posts, function(&$post, $link){
$post['positive'] = sql_select($link, "SELECT SUM(value) FROM author_vote WHERE post_id = $post['id']
AND value = 1");
$post['negative'] = abs(sql_select($link, "SELECT SUM(value) FROM author_vote WHERE post_id = $post['id']
AND value = -1"));
});
我还尝试了以下方法,这导致每个帖子的所有投票都相同:
foreach ($posts as &$post)
{
$id = $post['id'];
$post['positive'] = (int)sql_select($link, "SELECT SUM(value) FROM author_vote WHERE post_id = $id
AND value = 1");
$post['negative'] = (int)abs(sql_select($link, "SELECT SUM(value) FROM author_vote WHERE post_id = $id
AND value = -1"));
}
还有什么方法可以做到这一点,而不必为每个帖子多次查询数据库?不断变化的[像这样]如何被(mem)缓存?