gpt4 book ai didi

mysql - 按组合行对表进行排序

转载 作者:行者123 更新时间:2023-11-29 22:44:04 25 4
gpt4 key购买 nike

我有一个包含超过 5 亿行的数据库表,其结构如下:

|username  |date      |      units|
|user1 |2015-03-20| 5|
|user2 |2015-03-20| 7|
|user3 |2015-03-20| 3|
|user1 |2015-03-21| 9|
|user2 |2015-03-21| 4|
|user3 |2015-03-21| 11|

这当然是简化的,表中大约有 200 万个唯一用户名,每个用户名每天都会添加一个新行。

按过去 7 天(或该用户数据库中过去 7 个条目)的最高总单位排序的最佳方式是什么?我需要查看前 25 位左右的用户,返回他们的用户名及其组合单位

最佳答案

过滤、分组、排序和限制:

SELECT   username, SUM(units)
FROM myTable
WHERE date >= CURRENT_DATE - INTERVAL 7 DAY -- filter
GROUP BY username -- group
ORDER BY SUM(units) DESC -- sort
LIMIT 25 -- limit

如果使用 (username, date, units) 上定义的复合索引,此查询将是最佳的。 .

关于mysql - 按组合行对表进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29206015/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com