Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2003.07.03;
Скачать: CL | DM;

Вниз

Помогите красиво выбрать иерархические данные.   Найти похожие ветки 

 
Delph1   (2003-06-10 09:09) [0]

Имеется таблица структуры:
ID NUMBER(10) - Идентификатор
IDPARENT NUMBER(10) - Идентификатор вышестоящего
NAMES VARCHAR2(100) - Наименование

Обычная таблица для иерархических данных

Имеется N произвольно выбранных значений идентификаторов - из разных мест таблицы. Необходимо выбрать все записи, образующее дерево, на концах веток которого находятся узлы с указанными идентификаторами, т.е. выбрать указанные N записей и всех их предков. В результирующем наборе записи по ID повторяться не должны.

Спасибо.


 
passm ©   (2003-06-10 09:31) [1]

Delph1 (10.06.03 09:09)> Пахнет рекурсивным запросом :)
СУБД?


 
KSergey ©   (2003-06-10 09:32) [2]

Ну а это, слегка напрячься - не судьба?
Нужно оешение на SQL или как?


 
Johnmen ©   (2003-06-10 09:32) [3]

Зависит от БД...


 
Delph1   (2003-06-10 09:54) [4]

Oracle. На SQL. Есть способ для получения всех предков для указанного узла - connect by prior, start with. Сделал склейку запросов через UNION. Но не думаю, что это лучший способ. Хотелось бы узнать, может еще способы есть?


 
Johnmen ©   (2003-06-10 09:58) [5]

>Но не думаю, что это лучший способ.

Что именно ? connect by prior, start with или UNION ?


 
Delph1   (2003-06-10 10:04) [6]

UNION. Обьединение отдельных запросов для каждого идентификатора. При возрастании N растет время на формирование, разбор и выполнение запроса, да и размер запроса растет... Возможны ситуации, когда N = 500, а количество записей во всей таблице поряка 20000.


 
Наталия ©   (2003-06-10 10:07) [7]

Что-то ты путаешь...
Насколько мне не изменяет память connect by... находит не предков, а всех потомков.
Для поиска предков я писала простенькую рекурсивную функцию. На вход можно передать массив нужных id.


 
Sergey13 ©   (2003-06-10 10:08) [8]

2Delph1 (10.06.03 09:54)
>Сделал склейку запросов через UNION.
А зачем? Start with id in (твой перечень нужных узлов)


 
Delph1   (2003-06-10 10:11) [9]

> Sergey13 ©
> Start with id in

Так можно? Пробую...


 
Sergey13 ©   (2003-06-10 10:17) [10]

2Наталия © (10.06.03 10:07)
Изменяет вам память, Наташа. Тут все зависит от prior - что справа от = то и ищет. 8-)


 
Delph1   (2003-06-10 10:17) [11]

Все работает! Спасибо. Sergey13 - мастер :)


 
Наталия ©   (2003-06-10 10:23) [12]

Sergey13 © (10.06.03 10:17)
Да, ты прав. Освежила память. Совсем плоха стала... :))



Страницы: 1 вся ветка

Текущий архив: 2003.07.03;
Скачать: CL | DM;

Наверх




Память: 0.49 MB
Время: 0.02 c
1-7452
Silla
2003-06-23 12:50
2003.07.03
Как вставить текст в рисунок?


14-7724
NailMan
2003-06-17 17:29
2003.07.03
Мы видим элементарные частицы своими глазами


3-7367
grifon_nn
2003-06-09 17:43
2003.07.03
Резервная копия


1-7512
Sabor
2003-06-21 17:39
2003.07.03
Exe-файл


1-7443
stalker780
2003-06-23 13:35
2003.07.03
Отладка DLL