После создания 3 таблиц equip_type, output_history и time_history.
Этот код должен показать для каждой строки output_history самые последние данные в time_history.
И результат выглядит следующим образом.
EQUIP MODEL DATE1 QUANTITY DATE2 TIME EQUIP_TYPE
---- ---- ---------- ------ -------- ---- ----------
e1 m1 20180103 10 20180101 6 A
e1 m1 20180106 20 20180105 5 A
Но как я могу изменить код, чтобы показать строку, которая не имеет equip_type, как это.
EQUIP MODEL DATE1 QUANTITY DATE2 TIME EQUIP_TYPE
---- ---- ---------- ------ -------- ---- ----------
e1 m1 20180103 10 20180101 6 A
e1 m1 20180106 20 20180105 5 A
e2 m1 20180106 20 20180105 5 (null)
e3 m1 20180106 20 (null) (null) (null)
Код указан ниже;
CREATE TABLE equip_type (
EQUIP_TYPE VARCHAR(15),
EQUIP VARCHAR(15)
);
INSERT INTO equip_type VALUES ('A','e1');
CREATE TABLE output_history (
EQUIP VARCHAR(15),
MODEL VARCHAR(15),
Data1 VARCHAR(15),
QUANTITY NUMBER(10)
);
INSERT INTO output_history VALUES ('e1','m1','20180103',10);
INSERT INTO output_history VALUES ('e1','m1','20180106',20);
INSERT INTO output_history VALUES ('e2','m1','20180106',20);
INSERT INTO output_history VALUES ('e3','m1','20180106',20);
CREATE TABLE time_history (
EQUIP VARCHAR(15),
MODEL VARCHAR(15),
Data2 VARCHAR(15),
time NUMBER(10)
);
INSERT INTO time_history VALUES ('e1','m1','20180101',6);
INSERT INTO time_history VALUES ('e1','m1','20180105',5);
INSERT INTO time_history VALUES ('e2','m1','20180106',5); --added
SELECT
o.equip,
o.model,
o.data1,
o.quantity,
t.data2,
t.time,
e.equip_type
FROM
output_history o
INNER JOIN equip_type e ON e.equip = o.equip --I have tried RIGHT OUTER JOIN here, but didn' work
INNER JOIN time_history t ON t.equip = o.equip AND t.data2 <= o.data1
AND t.data2 >= '20180101'
WHERE NOT EXISTS (
SELECT 1
FROM time_history
WHERE
equip = o.equip
AND data2 <= o.data1
AND data2 > t.data2
AND data2 >= '20180101' AND data2 <= '2080106'
)AND o.data1 >= '20180101' AND o.data1 <= '20180106';