MySQL:查询带有关系的排行榜

时间:2011-08-16 00:18:29

标签: php mysql ranking leaderboard

我知道这是一个热门话题,但我仍然没有找到我正在寻找的东西。我想查询一个表

BOOKS_READ
id
user_id
book_id

格式化已将大多数图书列为已阅读的用户的排行榜。当用户阅读书籍时,与书籍ID和用户ID匹配的记录将被记录到books_read表中。

是否可以对此查询的结果进行排名,从1开始,并考虑关系?

SELECT user_id, COUNT(*) AS book_count 
FROM books_read 
GROUP BY user_id 
ORDER BY book_count DESC LIMIT 10

如果出现平局,我想在结果中列出'='符号。

例如,

rank  user_id  book_count  
=1    30       121
=1    17       121
 2    101      119
=3    11       104
=3    91       104

非常感谢您的帮助!我不介意使用PHP来处理其中的一些,但我对学习这些东西的直接SQL解决方案非常感兴趣: - )

2 个答案:

答案 0 :(得分:2)

SELECT GROUP_CONCAT(user_id, book_count
FROM (
    SELECT user_id, COUNT(*) AS book_count 
    FROM books_read 
    GROUP BY user_id 
    ORDER BY book_count DESC
) AS T1
GROUP BY book_count
ORDER BY book_count

给你

user_id  book_count  
30,17       121
101         119
11,91       104

然后您可以使用PHP来解析关系。

<?php
$rank = 1;

while ($row = mysql_fetch_assoc($result)) {
    $users = explode(',', $row['user_id'];
    foreach ($users as $user) {
        echo 'Rank: ' . $rank . ' ' . $user . "\n;
    }
    $rank++;
}

?>

答案 1 :(得分:1)

您要做的是计算得分高于您感兴趣的记录的人数,并添加1.

所以,如果你是最好的球员,零人得分会更高,所以0 + 1 =排名第一。

如果有五个人得分更高,无论他们中有多少人相依,你仍然是5 + 1 = 6。

问题是,对于您显示的每一行,这都是一种昂贵的查询。因此,您可能希望对结果集中的第一行执行此操作,然后在表示层(PHP)中为每个人添加一个。在你这样做的时候一定要考虑到这一点。

边缘条件是你不知道结果集中的第一行是否与“他”之前的人联系在一起。因此,您需要知道有多少人与结果集中的第一个人具有相同的分数。 (如果你从顶部开始,这不是问题。)