繁体   English   中英

多行到一行

[英]Multiple Rows to one row

我有一个棘手的问题。 (至少对我而言)我需要在一行而不是多行中获取具有相同 AdressNrADR 的行的所有值。 他们有办法做到这一点吗?

SELECT ADR_Adressen.AdressNrADR, CRM_Aufgaben.TerminVon, LAG_Artikel.ArtikelNrLAG, 
    PRO_Auftraege.Z_R_ckmeldung_Zusatzartikel, CRM_AufgabenLink.MitNrPRO FROM   ( ( ( ( ( ( ADR_Adressen 
    LEFT JOIN  PRO_Auftraege ON ADR_Adressen.AdressNrADR =  PRO_Auftraege.Kunde)  
    LEFT JOIN  CRM_Aufgaben ON PRO_Auftraege.AuftragNrPRO =  CRM_Aufgaben.AuftragNrPRO)  
    LEFT JOIN  CRM_Status ON CRM_Aufgaben.StatusCRM =  CRM_Status.StatusCRM)  
    LEFT JOIN  LAG_Artikel ON CRM_Aufgaben.ArtikelNrLAG =  LAG_Artikel.ArtikelNrLAG)  
    LEFT JOIN  ADR_GruppenLink ON ADR_Adressen.AdressNrADR =  ADR_GruppenLink.AdressNrADR)  
    LEFT JOIN  ADR_Gruppen ON ADR_GruppenLink.GruppeADR =  ADR_Gruppen.GruppeADR)  
    LEFT JOIN  CRM_AufgabenLink ON CRM_Aufgaben.AufgabenNrCRM =  CRM_AufgabenLink.AufgabenNrCRM 
    WHERE { d '2020-02-10'}<=CRM_Aufgaben.TerminVon AND { d '2020-02-16'}+1>=CRM_Aufgaben.TerminBis and CRM_AufgabenLink.MitNrPRO != 0 and CRM_Status.StatusCRM = 1 GROUP BY ADR_Adressen.AdressNrADR,CRM_Aufgaben.TerminVon,CRM_Aufgaben.TerminBis, ADR_Adressen.Name, ADR_Adressen.Vorname, LAG_Artikel.ArtikelNrLAG, LAG_Artikel.Bezeichnung1,CRM_AufgabenLink.MitNrPRO,PRO_Auftraege.Z_R_ckmeldung_Zusatzartikel 
    ORDER BY ADR_Adressen.Name

现在输出:

AdressNrADR TerminVon   ArtikelNrLAG    Z_R_ckmeldung_Zusatzartikel MitNrPRO
13507   2020-02-12 11:00:00.000 7601    7602    2169
13507   2020-02-13 15:00:00.000 7311    NULL    2337
13507   2020-02-14 10:00:00.000 7311    NULL    1028
12955   2020-02-11 08:00:00.000 7311    NULL    1028
12955   2020-02-11 14:00:00.000 3101    NULL    2347
12955   2020-02-13 10:00:00.000 7311    7352    1991
12955   2020-02-13 13:00:00.000 3101    NULL    2347
12955   2020-02-13 14:00:00.000 7311    NULL    1028
10007   2020-02-11 15:00:00.000 7601    7602    1806
10007   2020-02-14 13:00:00.000 7311    NULL    1833

期望输出:

AdressNrADR TerminVon1  ArtikelNrLAG1   Z_R_ckmeldung_Zusatzartikel1 MitNrPRO1 TerminVon2   ArtikelNrLAG2   Z_R_ckmeldung_Zusatzartikel2 MitNrPRO2 TerminVon3   ArtikelNrLAG3   Z_R_ckmeldung_Zusatzartikel3 MitNrPRO3
    13507   2020-02-12 11:00:00.000 7601    7602    2169 2020-02-13 15:00:00.000    7311    NULL    2337 2020-02-14 10:00:00.000    7311    NULL    1028

您可以使用条件聚合和row_number()

with cte as (
      <your query here>
     )
select AdressNrADR,
       max(case when seqnum = 1 then TerminVon end) as TerminVon1,
       max(case when seqnum = 1 then ArtikelNrLAG end) as ArtikelNrLAG1,
       . . .
       max(case when seqnum = 2 then TerminVon end) as TerminVon2,
       . . .
from (select cte.*, row_number() over (partition by AdressNrADR order by AdressNrADR) as seqnum
      from cte
     ) t
group by AdressNrADR;

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM