跳至主要內容
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?

4563博客

全新的繁體中文 WordPress 網站
  • 首頁
  • 请教数据库查询的聚合值的排序问题
未分類
24 1 月 2021

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

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

資深大佬 : diyazhu 5

有一个产品需求按照某个字段的值降序分页展示列表。可是这个字段的值是根据时间范围从数据库里累加而来得到的。

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

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

请教下各位大佬,这个需求一般怎么实现?

大佬有話說 (8)

  • 資深大佬 : chainzhao

    SELECT user ,SUM(value) from table where date BETWEEN 20200101 AND 20200103 GROUP BY user ORDER BY SUM(value) LIMIT(0,10);

  • 主 資深大佬 : diyazhu

    @chainzhao
    感谢回复。
    我的描述中简化了问题,假如是很多张子表呢。每天的数据在一张子表中。根据时间范围可能会从很多张表中捞数据出来

  • 資深大佬 : ebingtel

    mark……如果是微服务、多个接口的情况,如果对聚合值进行有效排序?

  • 資深大佬 : weizhen199

    @diyazhu 你最好再具体点,比如表分不分库

  • 主 資深大佬 : diyazhu

    @weizhen199 不分库。时间范围可能会是多个表里。这边只是举了个按照 sum(A)降序排列的需求。 其实还有表中的两列 B 、C,按照 sum(B) / sum(C) 降序排列的需求。

  • 資深大佬 : weizhen199

    @diyazhu 拉报表还是要求实时的。

  • 主 資深大佬 : diyazhu

    @weizhen199 报表

  • 主 資深大佬 : diyazhu

    补充一下,这应该不能直接用 sql 来做。会有多个表做 union,耗时、耗 db 的内存。大佬们实际工作遇到了是怎么处理的,新的组件或者其他?

文章導覽

上一篇文章
下一篇文章

AD

其他操作

  • 登入
  • 訂閱網站內容的資訊提供
  • 訂閱留言的資訊提供
  • WordPress.org 台灣繁體中文

51la

4563博客

全新的繁體中文 WordPress 網站
返回頂端
本站採用 WordPress 建置 | 佈景主題採用 GretaThemes 所設計的 Memory
4563博客
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?
在這裡新增小工具