【问题标题】:Impala - Calculate Percentage From One TableImpala - 从一张表计算百分比
【发布时间】:2018-12-04 03:17:38
【问题描述】:

我有这种表,命名为table_A

 Cust        Amount      Src_cust
  A           2000         B
  A           3000         C
  A           1000         B
  C           1000         B

结果

 Cust        Percentage  Src_cust
  A           50 %         B
  A           50 %         C
  C           100%         B

我想获取此类数据,我正在使用 impala 进行查询,但无法获取百分比。

Select Cust,(Sum(Amount) * 100) /sum(sum(Amount)) over() as  percentage, Src_cust
from table_A 

这段代码给了我结果:

Cust        Percentage  Src_cust
  A           0            B
  A           0            C
  C           0            B

请帮忙。谢谢你

【问题讨论】:

    标签: sql bigdata impala dbeaver


    【解决方案1】:

    您需要在尝试中进行一些聚合。我认为正确的查询是:

    select cust,
           sum(amount) * 100.0 /sum(sum(amount)) over (partition by cust) as  percentage, Src_cust
    from table_A
    group by cust, src_cust
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2011-05-25
      • 2015-01-02
      • 1970-01-01
      • 2022-11-15
      • 2023-02-01
      • 2011-06-01
      • 2021-01-10
      相关资源
      最近更新 更多