• 请不要在回答技术问题时复制粘贴 AI 生成的内容
diyazhu
V2EX  ›  程序员

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

  •  
  •   diyazhu · Jan 27, 2021 · 1956 views
    This topic created in 1959 days ago, the information mentioned may be changed or developed.
    有一个产品需求按照某个字段的值降序分页展示列表。可是这个字段的值是根据时间范围从数据库里累加而来得到的。

    比如有一个数据表
    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 replies    2021-01-28 20:34:19 +08:00
    chainzhao
        1
    chainzhao  
       Jan 27, 2021
    SELECT user ,SUM(value) from table where date BETWEEN 20200101 AND 20200103 GROUP BY user ORDER BY SUM(value) LIMIT(0,10);
    diyazhu
        2
    diyazhu  
    OP
       Jan 27, 2021
    @chainzhao
    感谢回复。
    我的描述中简化了问题,假如是很多张子表呢。每天的数据在一张子表中。根据时间范围可能会从很多张表中捞数据出来
    ebingtel
        3
    ebingtel  
       Jan 28, 2021
    mark……如果是微服务、多个接口的情况,如果对聚合值进行有效排序?
    weizhen199
        4
    weizhen199  
       Jan 28, 2021
    @diyazhu 你最好再具体点,比如表分不分库
    diyazhu
        5
    diyazhu  
    OP
       Jan 28, 2021
    @weizhen199 不分库。时间范围可能会是多个表里。这边只是举了个按照 sum(A)降序排列的需求。 其实还有表中的两列 B 、C,按照 sum(B) / sum(C) 降序排列的需求。
    weizhen199
        6
    weizhen199  
       Jan 28, 2021
    @diyazhu 拉报表还是要求实时的。
    diyazhu
        7
    diyazhu  
    OP
       Jan 28, 2021
    @weizhen199 报表
    diyazhu
        8
    diyazhu  
    OP
       Jan 28, 2021
    补充一下,这应该不能直接用 sql 来做。会有多个表做 union,耗时、耗 db 的内存。大佬们实际工作遇到了是怎么处理的,新的组件或者其他?
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   5347 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 38ms · UTC 09:09 · PVG 17:09 · LAX 02:09 · JFK 05:09
    ♥ Do have faith in what you're doing.