我知道这是一个热门话题,但我仍然没有找到我要找的东西。我想查询一张表
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/