首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >多行对应一行

多行对应一行
EN

Stack Overflow用户
提问于 2020-02-03 21:38:40
回答 1查看 48关注 0票数 0

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

代码语言:javascript
复制
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

现在输出:

代码语言:javascript
复制
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

所需输出:

代码语言:javascript
复制
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
EN

回答 1

Stack Overflow用户

发布于 2020-02-03 22:13:59

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

代码语言:javascript
复制
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;
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60040413

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档