基于部分公共字段合并数据

时间:2016-06-21 15:46:43

标签: sql oracle oracle10g

以下是我用于生成输出的查询

SELECT A.MGR_EMP_NBR,E.FIRST_NM || ' ' || E.LAST_NM AS EMP_NM , A.AE_EMP_NBR,a.sales_terr_id, COUNT ( * ) AS pre_leads_total FROM MKVW_ECOMPORTAL_SCHEMA.ECOMWEB_LEADS A    
left join MKVW_MKV_SCHEMA.EMPLOYEE E on A.MGR_EMP_NBR = E.EMP_NBR    
WHERE A.SALES_TERR_ID like '1-2-7-56-%-%-%' AND A.MGR_EMP_NBR is NULL    
GROUP BY A.MGR_EMP_NBR, E.FIRST_NM || ' ' || E.LAST_NM , A.AE_EMP_NBR,a.sales_terr_id

输出 -

MGR_EMP_NBR    EMP_NM   AE_EMP_NBR   sales_terr_id      pre_leads_total
                         1234        1-2-7-56-1-1-26    12
                         2311        1-2-7-56-1-1-27    11
                         414         1-2-7-56-1-5-26    10

我希望获得值的总和,其中 sales_terr_id 具有前6个数字作为通用含义合并1-2-7-56-1-1-26 and 1-2-7-56-1-1-27并将合并的sales_terr_id指定为1-2-7-56-1 -1-0。 所以在这种情况下我想得到输出

预期产出 -

  MGR_EMP_NBR    EMP_NM   AE_EMP_NBR   sales_terr_id      pre_leads_total
                             1234        1-2-7-56-1-1-0    23
                             414         1-2-7-56-1-5-0    10

是否可能。我不关心AE_EMP_NBR。

1 个答案:

答案 0 :(得分:1)

如果要按sales_terr_id的前6个数字元素进行分组,可以按其子字符串进行分组;因为它们都是数字,你可以使用正则表达式:

with t(MGR_EMP_NBR, EMP_NM, AE_EMP_NBR, sales_terr_id, pre_leads_total) as (
  select null, null, 1234, '1-2-7-56-1-1-26', 12 from dual
  union all select null, null, 2311, '1-2-7-56-1-1-27', 11 from dual
  union all select null, null, 414, '1-2-7-56-1-5-26', 10 from dual
)
select mgr_emp_nbr, emp_nm, min(ae_emp_nbr) as ae_emp_nbr,
  regexp_substr(sales_terr_id, '(\d+-){6}') ||'0' as sales_terr_id,
  sum(pre_leads_total) as pre_leads_total
from t
group by mgr_emp_nbr, emp_nm, regexp_substr(sales_terr_id, '(\d+-){6}');

MGR_EMP_NBR EMP_NM AE_EMP_NBR SALES_TERR_ID    PRE_LEADS_TOTAL
----------- ------ ---------- ---------------- ---------------
                          414 1-2-7-56-1-5-0                10
                         1234 1-2-7-56-1-1-0                23

你必须汇总ae_emp_nbr,所以我使用了min() - 你说你并不关心。

如果您希望一次性在现有查询中执行此操作,则可能是:

select a.mgr_emp_nbr,
  e.first_nm || ' ' || e.last_nm as emp_nm,
  min(a.ae_emp_nbr) as ae_emp_nbr,
  regexp_substr(a.sales_terr_id, '(\d+-){6}') ||'0' as sales_terr_id,
  count (*) as pre_leads_total
from ecomweb_leads a    
left join employee e on a.mgr_emp_nbr = e.emp_nbr    
where a.sales_terr_id like '1-2-7-56-%-%-%'
and a.mgr_emp_nbr is null    
group by a.mgr_emp_nbr, e.first_nm || ' ' || e.last_nm,
  regexp_substr(a.sales_terr_id, '(\d+-){6}')