mysql中Max Value的总和

时间:2018-11-06 02:07:13

标签: mysql

我尝试从表中获取最大值的总和:

select 
  a.sp_capex_01_master_key,
  a.sp_capex_01_master_wbs_id,
  format((
  (
    select
      sum(maxVal)
    from 
      (
        select max(w.sp_capex_01_trans_realisasi) as maxVal 
        from sp_capex_01.sp_capex_01_trans w 
        where w.sp_capex_01_master_wbs_id='P2-14101-01' 
        group by w.sp_capex_01_master_key 
      ) t
  ) / b.sp_capex_01_master_wbs_bud * 100
  ),2) as 'PerBudget'
from sp_capex_01_master a
join sp_capex_01.sp_capex_01_master_wbs b 
  on a.sp_capex_01_master_wbs_id=b.sp_capex_01_master_wbs_id;

如果我将值设置为w.sp_capex_01_master_wbs_id='P2-14101-01',那么得到的结果将带有错误的值。

但是当我将其更改为w.sp_capex_01_master_wbs_id=a.sp_capex_01_master_wbs_id时,我收到以下错误消息:

Error Code: 1054. Unknown column 'a.sp_capex_01_master_wbs_id' in 'where clause'    0.000 sec

如何获得最大值的总和?

1 个答案:

答案 0 :(得分:0)

加入一个子查询,该子查询按您要匹配的列进行分组。

SELECT 
  a.sp_capex_01_master_key,
  a.sp_capex_01_master_wbs_id,
  FORMAT(sum_maxval / b.sp_capex_01_master_wbs_bud * 100, 2) AS PerBudget
FROM sp_capex_01_master a
JOIN sp_capex_01.sp_capex_01_master_wbs b ON a.sp_capex_01_master_wbs_id=b.sp_capex_01_master_wbs_id
LEFT JOIN (
    SELECT sp_capex_01_master_wbs_id, SUM(maxVal) AS sum_maxval
    FROM (
        select w.sp_capex_01_master_wbs_id, max(w.sp_capex_01_trans_realisasi) as maxVal 
        from sp_capex_01.sp_capex_01_trans w 
        group by w.sp_capex_01_master_wbs_id, w.sp_capex_01_master_key
    ) AS w1
    GROUP BY sp_capex_01_master_wbs_id
) AS w2 ON w2.sp_capex_01_master_wbs_id = a.sp_capex_01_master_wbs_id