Chcę wstawić dane do 3 tabel za pomocą jednego zapytania.
Moje tabele wyglądają jak poniżej:
CREATE TABLE sample (
id bigserial PRIMARY KEY,
lastname varchar(20),
firstname varchar(20)
);
CREATE TABLE sample1(
user_id bigserial PRIMARY KEY,
sample_id bigint REFERENCES sample,
adddetails varchar(20)
);
CREATE TABLE sample2(
id bigserial PRIMARY KEY,
user_id bigint REFERENCES sample1,
value varchar(10)
);
Otrzymam klucz w zamian za każde włożenie i muszę wstawić ten klucz do następnej tabeli.
Moje zapytanie to:
insert into sample(firstname,lastname) values('fai55','shaggk') RETURNING id;
insert into sample1(sample_id, adddetails) values($id,'ss') RETURNING user_id;
insert into sample2(user_id, value) values($id,'ss') RETURNING id;
Ale jeśli uruchamiam pojedyncze zapytania, po prostu zwracają mi wartości i nie mogę ich natychmiast użyć ponownie w następnym zapytaniu.
Jak to osiągnąć?