Форум программистов, компьютерный форум, киберфорум
Oracle
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.87/15: Рейтинг темы: голосов - 15, средняя оценка - 4.87
1 / 1 / 3
Регистрация: 27.11.2012
Сообщений: 146

Иерархический запрос

16.09.2015, 14:59. Показов 3085. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Иерархический запрос по двум таблицам.

Как написать запрос, что бы получить дерево.

Дано:

Две таблицы: tab1, tab2.

Таблица tab1 содержит поля: id, parent

Таблица tab2 содержит поля: id, parent

Множества Id каждой таблицы не пересекаются, то есть они уникальны.

Поле parent может содержать как id из первой таблицы, так и из второй.

То есть получаем иерархию на основе двух таблиц. Одна таблица при поиске потомков отсылает к другой или к самой себе. Другая в свою очередь тоже отсылает к себе или к другой таблице.

*

Задача:

Есть id.

Нужно написать запрос, выводящий список всех потомков на всех уровнях из обеих таблиц. С одной таблицей всё понятно:

Oracle 11 SQL
1
2
3
4
SELECT LEVEL, tab1.id
FROM tab1
CONNECT BY tab1.parent = PRIOR tab1. id
START WITH tab1.parent=555
А вот для такой иерархии не могу понять, какой должен быть запрос. Помогите, пожалуйста.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.09.2015, 14:59
Ответы с готовыми решениями:

Иерархический запрос
Здравствуйте. Читаю вот эту статью https://habr.com/post/43955/. Там есть такой абзац "Условие после CONNECT BY нужно указать...

CONNECT BY иерархический запрос
У меня есть несколько таблиц, из них я при помощи запроса SELECT a3.MANAG_NUMB, a3.PARENT_MANAG_NUMB, a3.MANAG_NAME, SUM(a4.PRICE) ...

Куда добавлять условие в иерархический запрос?
Условие: Выведите иерархию подчинений воинских подразделений сверху вниз, начиная с полка 'Regiment #1271A', и численность личного...

6
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
16.09.2015, 15:13
Цитата Сообщение от dima-dima Посмотреть сообщение
Множества Id каждой таблицы не пересекаются, то есть они уникальны.
Поле parent может содержать как id из первой таблицы, так и из второй.
Почему из этих двух таблиц не сделать одну?

PS
Если все таки нельзя, то в запросе их можно объединить по UNION ALL
1
105 / 49 / 26
Регистрация: 01.09.2014
Сообщений: 140
16.09.2015, 15:13
Лучший ответ Сообщение было отмечено dima-dima как решение

Решение

SQL
1
2
3
4
5
SELECT level, t.id
FROM (SELECT id, parent FROM tab1 UNION
      SELECT id, parent FROM tab2) t
CONNECT BY t.parent = prior t.id
START WITH t.parent=555
0
1 / 1 / 3
Регистрация: 27.11.2012
Сообщений: 146
16.09.2015, 15:15  [ТС]
Вкратце, запрещено их объединять. Это уже рабочая система, такие изменения делать запрещено.
0
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
16.09.2015, 15:20
Цитата Сообщение от dima-dima Посмотреть сообщение
запрещено их объединять
Ну да. При проектировании создаем себе трудности, а потом при написании запросов мужественно их преодолеваем
Хорошо еще, если в дальнейшем подобные ляпы проектирования не приведут к недопустимым тормозам.
0
1 / 1 / 3
Регистрация: 27.11.2012
Сообщений: 146
16.09.2015, 15:22  [ТС]
Этот ляп перетащен и одной импортной коммерческой системы одной крупной компании.
0
105 / 49 / 26
Регистрация: 01.09.2014
Сообщений: 140
16.09.2015, 16:12
Если слишком медленно то имеет смысл написать хотя бы функцию, искать сначало в tab1 и если не нашлось то потом уже искать в tab2.
Или как вариант сделать мат вью и ней уже искать.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
16.09.2015, 16:12
Помогаю со студенческими работами здесь

Иерархический запрос из двух таблиц в PL/SQL
Здравствуйте. Есть 2 таблицы в pl/sql с именами test_litv1 и test_litv2. Нужно составить процедуру, выводящую иерархическую структуру по 2м...

Иерархический запрос с выбором лишь одного(первого) потомка
Здравствуйте! Помогите разобраться. Есть две таблицы history_in и history_out хранят историю изменений детали. Связаны таблицы по полю...

Иерархический запрос
Добрый вечер! Нужна ваша помощь. Имеется иерархический запрос, который строит представление. Суть проблемы в том, что в какой-то момент...

Построить иерархический запрос
Добрый день, проблема описана в заголовке. Средствами языка (c#) я могу её решить выбрав просто записи а затем сгруппировать, но это не...

Есть ли у SQL SERVER иерархический запрос
Есть ли у SQL SERVER иерархический запрос аналогичный Оракловому select * from <name> connect by prior Спасибо


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru