или скажите куда мне пойти с такими вопросами)
Есть таблица со ссылкой на себя для иерархии
Нужно заполнить изначальную таблицу SQL-скриптом
Выходит что-то такое:
INSERT INTO region (id, name, belong_to_id)
VALUES (nextval('region_sequence'), 'Parent Region', NULL),
(nextval('region_sequence'), 'Child Region', '?');
Вопрос - как правильно это сделать, если вторая запись должна получить в поле айди первой?
При этом иерархия может быть 4-5 уровней в глубину и под одной записью может быть много зависимых
Есть вариант наплодить инсёртов на каждый уровень иерархии и вытягивать данные предыдущего для следующего (или через WITH AS RETURNING, с тем же смыслом)
Есть ли варианты лучше/оптимальнее?
База Postgres, скрипт накатывает Liquibase
INSERT INTO region (id, name, belong_to_id) VALUES (nextval('region_sequence'), 'Parent Region', NULL), (CURRVAL('region_sequence'), 'Child Region', '?'), (CURRVAL('region_sequence'), 'Child2 Region', '?'); возможно так )
Могу ошибаться, но это ведь попытается создать 3 записи с одним айди и упадёт, ввиду того что айди уникальный? Айди родителя должен идти 3м параметром, там где belong_to_id А если передавать nextval, 'Child', currval - то в currval будет значение для этой же записи. А если нет - то для следующего, если он должен быть под этим же родителем, всё равно будет уже другое
Обсуждают сегодня