Есть иерархический каталог. Есть продукты. Как объединить? Предположим, у нас есть иерархический библиотечный каталог. И есть книги, отнесенные к разделам каталога. Как построить дерево, включающее и каталог, и книги, включенные в это дерево в виде листьев? Каталог - это изначально иерархическая структура: (id, parent_id, text) Книги - это плоская структура со ссылкой (topic_id) на каталог: (id, authors, title, year, topic_id) Они хранятся в разных таблицах базы данных. Как их объединить в единый иерархический запрос? Если мы хотим построить дерево иерархии по изначально иерархической таблице каталога, то это в Oracle очень просто: select id, parent_id, text
from digest.lib_topics_vi
start with parent_id is null
connect by prior id = parent_id
;
1 Образование
2 1 Дошкольное образование
3 1 Высшее образование Но мы хотим "подвесить" публикации в это же дерево. Это значит, что нам необходимо расширить таблицу (представление) каталога, присоединив к ней данные из таблицы публикаций, но т