groupby和aggregate函数不在一起组合(同一组下的多个聚合数)

时间:2018-02-08 23:14:57

标签: plsql group-by aggregate plsqldeveloper

我有两张桌子,我想分组并得到总值的总和

select t.originfacilitycode, sum(t.cnt_total),t.soldto,
  case when t.product_id in ('81','36','76','384') then 'Expedited'
   when t.product_id in ('77','82','83','383') then 'Ground'
   when t.product_id in('631') then 'Max' end as parcel_category
    from ops_owner.volume_summary_month t, 
  ops_owner.account_data_pickup p 
 where t.soldto = p.soldto
 and t.product_id in ('81','36','76','384','77','82','83','383','631')
and  t.year = '2017'
and t.month in ('11','12')
   and t.soldto  = '5112087'


group by p.customer_name, t.originfacilitycode,t.soldto,
  case when t.product_id in ('81','36','76','384') then 'Expedited'
   when t.product_id in ('77','82','83','383') then 'Ground'
   when t.product_id in('631') then 'Max' end 

having sum(t.cnt_total) > 60

但是,结果并非按组分组唯一。

ORIGINFACILITYCODE  SUM(T.CNT_TOTAL)    SOLDTO  PARCEL_CATEGORY
USEWR1                  156864          5112087 Expedited
USEWR1                   78432          5112087 Expedited

如果我按照ORIGINFACILITYCODE,SOLDTO,PARCEL_CATEGORY进行分组,为什么我们得到多次返回,应该分组,对吗?

ops_owner.account_data_pickup有以下重复,但它应该选择第一个,对吗?

 SOLDTO      PICKUP CUSTOMER_NAME
 5112087    5314711 GOGOTECH
 5112087    5320536 GOGOTECH II, LLC

ops_owner.volume_summary_month已将sold_to列为

更新

我为同一帐户提取voluem

select t.originfacilitycode, sum(t.cnt_total) 
from ops_owner.volume_summary_month t
where t.soldto = '5112087'
and  t.year = '2017'
and t.month in ('11','12')

group by t.originfacilitycode


ORIGINFACILITYCODE  SUM(T.CNT_TOTAL)
USATL1                   1
USEWR1                  78432
USDFW1                   1

任何人都有任何线索?为什么我的第一个查询有第一行?

ORIGINFACILITYCODE  SUM(T.CNT_TOTAL)    SOLDTO  PARCEL_CATEGORY
USEWR1                  156864          5112087 Expedited

1 个答案:

答案 0 :(得分:1)

查看此查询

SELECT
    T.originfacilitycode,
    T.cnt_total,
    T.soldto,
    CASE 
        WHEN T.product_id IN ('81','36','76','384') THEN 'Expedited'
        WHEN T.product_id IN ('77','82','83','383') THEN 'Ground'
        WHEN T.product_id IN('631') THEN 'Max'
    END AS parcel_category
FROM
    ops_owner.volume_summary_month T,
    ops_owner.account_data_pickup P 
WHERE
    T.soldto = P.soldto
    AND T.product_id IN ('81','36','76','384','77','82','83','383','631')
    AND T.YEAR = '2017'
    AND T.MONTH IN ('11','12')
    AND T.soldto  = '5112087'
GROUP BY
    P.customer_name,
    T.originfacilitycode,
    T.soldto,
    CASE 
        WHEN T.product_id IN ('81','36','76','384') THEN 'Expedited'
        WHEN T.product_id IN ('77','82','83','383') THEN 'Ground'
        WHEN T.product_id IN('631') THEN 'Max'
    END AS parcel_category
HAVING SUM(T.cnt_total) > 60

正如您已经评论过的那样,P.customer_name处有多个不同的值,因此这是重复行的原因。

您必须在此处选择所需的行为:

  • 从该组中删除t.cnt_total,从所有可能的值中取出P.customer_name
  • P.customer_name
  • 上有多个值时,定义另一种行为