Salesforce Marketing Cloud SQL PIVOT

Я пытаюсь создать сводку в SFMC, чтобы объединить несколько строк в один столбец. Запрос выполняется успешно, но не заполняется правильно. В моей таблице 2 столбца: адрес электронной почты и product_sku. Каждый адрес электронной почты появляется в таблице 3 раза с другим product_sku рядом с ним. Я хочу, чтобы у вывода был уникальный адрес электронной почты с 3 product_skus

Пример файла:

Электронная почта | product_sku
[email protected] | 12314321131412
[email protected] | 45353643645
[email protected] | 0953242425352

Пример желаемого результата:

электронная почта | product_sku_header_1 | product_sku_header_2 | product_sku_header_3
---------------------------------------------- -----------------------------------
[email protected] | 12314321131412 | 45353643645 | 0953242425352

Мой запрос:

select
email
, sum(case when product_sku ='%' then 1 else 0 end) as product_sku_header_1
, sum(case when product_sku ='%' then 1 else 0 end) as product_sku_header_2
, sum(case when product_sku ='%' then 1 else 0 end) as product_sku_header_3
FROM data_extension
group by 
email

Заранее спасибо!


person JaylovesSQL    schedule 07.11.2019    source источник


Ответы (1)


Вы можете использовать row_number() для условного агрегирования:

select email,
       max(case when seqnm = 1 then product_sku end) as  product_sku_header_1,
       max(case when seqnm = 2 then product_sku end) as  product_sku_header_2,
       max(case when seqnm = 3 then product_sku end) as  product_sku_header_3
from (select de.*,
             row_number() over (partition by email order by product_sku) as seqnum
      from data_extension de
     ) de
group by email;
person Gordon Linoff    schedule 07.11.2019