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

Вниз

DELPHI, Paradox и древовидные структуры данных   Найти похожие ветки 

 
OneOfTheFew   (2003-03-20 13:29) [0]

Уважаемые Мастера !
Помогите решить такую задачу (желательно стандартными средствами: Delphi и Local SQL):

Есть парадоксовская таблица, описывающая древовидную стуктуру:
<Persons.db>
Person_id I
Parent_id I
Person_Name A(30)

Как получить список всех Person_id подчиненных указанному элементу непосредственно и опосредовано? Понятно, что глубина вложенности дерева практически не ограничена.

Заранее благодарю за помощь!


 
Соловьев ©   (2003-03-20 13:31) [1]

select PersonID
from Persons
where ParentId=10


 
OneOfTheFew   (2003-03-20 17:42) [2]

2 Соловьев

Не, Вы не поняли. Мне нужно "вычленить" поддерево все, а Ваше решение выдает только прямых "детишек". А как насчет "внуков" и "правнуков" ???


 
Соловьев ©   (2003-03-20 17:46) [3]

на парадоксе такое не решаемо...хотя в цыкле программно, а вот на IB и ему подобных с ХП вполне. www.ibase.ru там есть классные примеры...


 
Mike Kouzmine   (2003-03-20 17:50) [4]

Возьми пролог. Там это считается одной строчкой :)


 
Zelius ©   (2003-03-20 22:24) [5]

для твоей задачи может пригодиться такое решение: создать дополнительную таблицу Parent_ID, Person_ID, в которой будут харниться все пары Parent_ID со всеми возможными потомками Person_ID.

пример основной таблицы:
1 0 Петров
2 1 Иванов
3 2 Сидоров
4 2 Орлов
5 4 Козлов
а так будет выглядеть дополнительная таблица:
1 2
1 3
1 4
1 5
2 3
2 4
2 5
4 5


 
OneOfTheFew   (2003-03-21 14:05) [6]

Всем Спасибо!



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

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

Наверх




Память: 0.47 MB
Время: 0.018 c
6-30483
JMER
2003-02-10 10:05
2003.04.10
CGI - exe поиск сервера


14-30591
nayk
2003-02-18 02:53
2003.04.10
Подскажите где найти инфу по SMS


14-30531
alex134
2003-03-23 18:28
2003.04.10
Какой ассемблер взять?


14-30522
RDA
2003-03-23 21:37
2003.04.10
Для жителей Украины работающих с казначейством


7-30635
HardClubber
2003-02-13 22:16
2003.04.10
Com port