请教数据库查询的聚合值的排序问题

2021-01-27 19:55:21 +08:00
 diyazhu
有一个产品需求按照某个字段的值降序分页展示列表。可是这个字段的值是根据时间范围从数据库里累加而来得到的。

比如有一个数据表
date user value
20200101 111111 100
20200102 111111 200
20200103 111111 300
20200101 222222 101
20200102 222222 202

假如选择的时间范围是 20200101-20200103,根据 user 汇总 value,然后根据 sum value 降序排列,分页展示列表。


请教下各位大佬,这个需求一般怎么实现?
1120 次点击
所在节点    程序员
8 条回复
chainzhao
2021-01-27 20:43:49 +08:00
SELECT user ,SUM(value) from table where date BETWEEN 20200101 AND 20200103 GROUP BY user ORDER BY SUM(value) LIMIT(0,10);
diyazhu
2021-01-27 23:17:53 +08:00
@chainzhao
感谢回复。
我的描述中简化了问题,假如是很多张子表呢。每天的数据在一张子表中。根据时间范围可能会从很多张表中捞数据出来
ebingtel
2021-01-28 08:57:45 +08:00
mark……如果是微服务、多个接口的情况,如果对聚合值进行有效排序?
weizhen199
2021-01-28 09:20:32 +08:00
@diyazhu 你最好再具体点,比如表分不分库
diyazhu
2021-01-28 09:55:58 +08:00
@weizhen199 不分库。时间范围可能会是多个表里。这边只是举了个按照 sum(A)降序排列的需求。 其实还有表中的两列 B 、C,按照 sum(B) / sum(C) 降序排列的需求。
weizhen199
2021-01-28 13:40:53 +08:00
@diyazhu 拉报表还是要求实时的。
diyazhu
2021-01-28 13:59:26 +08:00
@weizhen199 报表
diyazhu
2021-01-28 20:34:19 +08:00
补充一下,这应该不能直接用 sql 来做。会有多个表做 union,耗时、耗 db 的内存。大佬们实际工作遇到了是怎么处理的,新的组件或者其他?

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/749022

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX