Я работаю в DB2 v11.1
У меня есть таблица в следующем формате:
CREATE TABLE SCHEMA.TEST_TABLE (
NAME VARCHAR(5)
,RATING VARCHAR(4)
,AAA_X INTEGER
,AAA_Y INTEGER
,BBB_X INTEGER
,BBB_Y INTEGER
,CCC_X INTEGER
,CCC_Y INTEGER
,DDD_X INTEGER
,DDD_Y INTEGER
)
INSERT INTO SCHEMA.TEST_TABLE (
NAME, RATING, AAA_X, AAA_Y, BBB_X, BBB_Y, CCC_X, CCC_Y,DDD_X,DDD_Y)
VALUES
('a','AAA',10,0,20,10,15,20,30,40),
('b','BBB',20,5,40,10,20,10,10,20),
('c','CCC',30,15,50,10,5,12,30,40)
Давайте для простоты назовем name как TRADE. Порядок рейтинга: AAA> BBB> CCC> DDD и так далее. Мне нужно набрать _X и _Y в случае, если рейтинг упадет на 2 для каждой сделки.
На основании приведенной выше таблицы для сделки 'a', если рейтинг упадет на 2 (AAA> CCC), тогда CCC_X и CCC_Y должны быть выбраны и показаны в следующем формате. Если он опустится на 3, тогда (AAA> DDD) и DDD_X и DDD_Y должны быть выбраны. Для сделки «b» падение рейтинга на 2 означает BBB> DDD.
Если он будет go ниже последнего доступного рейтинга (DDD в этом примере), то выберите последний доступный.
name | 2_drop_X | 2_drop_Y | 3_drop_X | 3_drop_Y
a 15 20 30 40
b 10 20 10 20
c 30 40 30 40
Пока что у меня есть следующее:
SELECT
ID, RATE, VALUE, TYPE
FROM SCHEMA.TEST_TABLE
LATERAL(VALUES
(P.NAME, P.RATING, AAA_X,'AAA_X'),
(P.NAME, P.RATING, AAA_Y,'AAA_Y'),
(P.NAME, P.RATING, BBB_X,'BBB_X'),
(P.NAME, P.RATING, BBB_Y,'BBB_Y'),
(P.NAME, P.RATING, CCC_X,'CCC_X'),
(P.NAME, P.RATING, CCC_Y,'CCC_Y'),
(P.NAME, P.RATING, DDD_X,'DDD_X'),
(P.NAME, P.RATING, DDD_Y,'DDD_Y')
) AS T(ID,RATE,VALUE,TYPE)
Расстояние между оценками не изменится, то есть AAA всегда будет на 2 позиции дальше от CCC. Я думал создать таблицу сопоставления и выполнить объединение на основе этого, но я застрял.
Таблица сопоставления в теме:
CREATE TABLE SCHEMA.TEST_MAPPING
(
TYPE VARCHAR(10)
,RATING VARCHAR(4)
,X_POS INTEGER
,Y_POS INTEGER
)
INSERT INTO SCHEMA.TEST_MAPPING
('AAA_X','AAA',1,0),
('AAA_Y','AAA',0,1),
('BBB_X','BBB',2,0),
('BBB_Y','BBB',0,2),
('CCC_X','CCC',3,0),
('CCC_Y','CCC',0,3),
('DDD_X','DDD',4,0),
('DDD_Y','DDD',0,4)
Я иду в неправильном направлении? Заранее спасибо
Редактировать: грамматика