首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >对按日期分组的所有条目“循环”相同的SQL查询

对按日期分组的所有条目“循环”相同的SQL查询
EN

Stack Overflow用户
提问于 2021-04-26 04:38:27
回答 1查看 49关注 0票数 0

我有一张这样的桌子:

代码语言:javascript
运行
复制
+------------+-----------+------+----+
|    date    | player_id | rank | hp |
+------------+-----------+------+----+
| 2021-01-01 |         1 |    1 | 39 |
| 2021-01-01 |         5 |    2 | 20 |
| 2021-01-01 |         2 |    3 | 12 |
| 2021-01-01 |         3 |    4 | 48 |
| 2021-01-01 |         4 |    5 | 25 |
| 2021-01-02 |         1 |    2 | 42 |
| 2021-01-02 |         2 |    1 | 38 |
| 2021-01-02 |         3 |    4 | 21 |
| 2021-01-02 |         4 |    3 | 35 |
| 2021-01-02 |         5 |    5 | 28 |
| 2021-01-03 |         1 |    5 | 38 |
| 2021-01-03 |         3 |    2 | 31 |
| 2021-01-03 |         2 |    3 | 26 |
| 2021-01-03 |         4 |    4 | 22 |
| 2021-01-03 |         5 |    1 | 19 |
+------------+-----------+------+----+

当我使用以下SQL代码时:

代码语言:javascript
运行
复制
SELECT * FROM
(SELECT * FROM `players` WHERE date='2021-01-01' ORDER BY rank ASC LIMIT 3) highest_rank
ORDER BY hp DESC LIMIT 2

结果将是:

代码语言:javascript
运行
复制
+------------+-----------+------+----+
|    date    | player_id | rank | hp |
+------------+-----------+------+----+
| 2021-01-01 |         1 |    1 | 39 |
| 2021-01-01 |         5 |    2 | 20 |
+------------+-----------+------+----+

我的问题是结果只针对date='2021-01-01‘。我想在数据库中每天都这样做。最终,我希望结果如下所示:

代码语言:javascript
运行
复制
+------------+-----------+------+----+
|    date    | player_id | rank | hp |
+------------+-----------+------+----+
| 2021-01-01 |         1 |    1 | 39 |
| 2021-01-01 |         5 |    2 | 20 |
| 2021-01-02 |         1 |    2 | 42 |
| 2021-01-02 |         2 |    1 | 38 |
| 2021-01-03 |         3 |    2 | 31 |
| 2021-01-03 |         2 |    3 | 26 |
+------------+-----------+------+----+

如何做到这一点?我正在使用MySQL/MariaDB,如果这有什么不同的话。

EN

Stack Overflow用户

发布于 2021-04-27 02:14:15

问题解决了。功劳归功于评论部分的粘性位,它提供了一个几乎有效的解决方案。他收回了这个建议,因为我认为这不是最终的解决方案。但我对它进行了修补,并使其正常工作。谢谢,sticky bit!

对于任何对该解决方案感兴趣的人:

代码语言:javascript
运行
复制
SELECT date, player_id, rank, hp
FROM
(
    SELECT *,
    row_number() OVER (PARTITION BY date 
               ORDER BY hp DESC) h
    FROM
    (
        SELECT *,
        row_number() OVER (PARTITION BY date
                   ORDER BY rank ASC) r
        FROM players
    ) x
    WHERE r<=3
) y 
WHERE h<=2
票数 1
EN
查看全部 1 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67258067

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档