Поворот SQL в Teradata - PullRequest
       17

Поворот SQL в Teradata

0 голосов
/ 23 октября 2018

Мне нужно преобразовать строки в несколько выходных столбцов.

У меня есть 2 таблицы, которые мне нужно объединить и создать третью таблицу, которая хранится здесь.

enter image description here

CREATE MULTISET TABLE TAG
( TAG VARCHAR(100), 
  ID VARCHAR(100)
) PRIMARY INDEX (TAG,ID);

INSERT INTO TAG VALUES('L2250','I14299');
INSERT INTO TAG VALUES('L2250','I14300');
INSERT INTO TAG VALUES('L2250','I14301');

CREATE MULTISET TABLE IDS
( ID VARCHAR(100),
  TYPE VARCHAR(100),
  DESCR VARCHAR(100)
) ;

INSERT INTO IDS VALUES ('I14299','Exposure','Bills');
INSERT INTO IDS VALUES ('I14299','Exposure','Certificates');
INSERT INTO IDS VALUES ('I14299','Exposure','NCDS');
INSERT INTO IDS VALUES ('I14300','Currency','GB');
INSERT INTO IDS VALUES ('I14300','Currency','AU');
INSERT INTO IDS VALUES ('I14301','Rate','NOT FIXED');
INSERT INTO IDS VALUES ('I14301','Rate','FIXED');

1 Ответ

0 голосов
/ 23 октября 2018

Это не Pivot и Unpivot, вы хотите создать все возможные комбинации разных типов:

SELECT *
FROM 
 ( SELECT t.tag, i.descr AS I14299
   FROM tag AS t JOIN ids AS i
     ON t.id = i.id
   WHERE i.id = 'I14299'
 ) AS e
CROSS JOIN
 ( SELECT descr AS I14300
   FROM ids
   WHERE id = 'I14300'
 ) AS c
CROSS JOIN
 ( SELECT descr AS I14301
   FROM ids
   WHERE id = 'I14301'
 ) AS r

Если вам нужно сделать это для разных тегов, вы можете переключиться на:

SELECT e.*, c.descr, r.descr
FROM 
 ( SELECT t.tag, i.descr AS I14299
   FROM tag AS t JOIN ids AS i
     ON t.id = i.id
   WHERE t.id = 'I14299'
 ) AS e
JOIN
 ( SELECT t.tag, descr AS I14300
   FROM tag AS t JOIN ids AS i
     ON t.id = i.id
   WHERE t.id = 'I14300'
 ) AS c
ON e.tag = c.tag   
JOIN
 ( SELECT t.tag, descr AS I14301
   FROM tag AS t JOIN ids AS i
     ON t.id = i.id
   WHERE t.id = 'I14301'
 ) AS r
ON e.tag = r.tag

Конечно, это жестко кодирует идентификаторы, если вы хотите, чтобы они создавались динамически, вам нужен динамический SQL в хранимой процедуре.

...