php - MySQL:查询有领带的排行榜

标签 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 解决方案非常感兴趣:-)

最佳答案

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

?>

关于php - MySQL:查询有领带的排行榜,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7072276/

相关文章:

php - 为我的学士学位构建 cms 并需要一些建议

php - 使用 PHPExcel 按行和列将 Excel 中的单元格合并在一起

php - MySQL 更新时间

sql - 在 MS SQL Server 2008 中返回行递增的结果

sql - 在 PostgreSQL 中对多个唯一值进行排名的函数

ios - swift 中的排名数字循环

php - MySQL REPLACE 行,其中字段 a 等于 x,字段 b 等于 y

mysql - MariaDB 按日期排序并限制偏移量和缺失结果

php - 使用 Codeigniter 将表单输入中的字符串添加到 URL

php - MySQL 将 IP 存储为 int 以获得更高的性能?