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

Вниз

Хитрый SQL на древовидная структуре   Найти похожие ветки 

 
Vagrant ©   (2002-11-01 03:13) [0]

Привет! У меня такой вопрос:
Есть таблица в которой храниться дерево
ID integer
ParentID integer
Data String

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


 
Vagrant ©   (2002-11-01 03:16) [1]

Вопрос в догонку. Поддерживает ли FireBird рекурсивные запросы?


 
Dr_Mike ©   (2002-11-01 03:19) [2]

При такой простой организации дерева есть только один способ - перебор всех записей по порядку в отсортированной по ParentID(в порядке возрастания) таблицы с одновременным ребилдингом кастового дерева


 
Dr_Mike ©   (2002-11-01 03:21) [3]

И как же ты хочешь организовать эти рекурсивные запросы ?


 
Vagrant ©   (2002-11-01 04:39) [4]

В оракле это возможно посредством операторов
CONNECT BY и START WITH. Вот я и думал что в Interbase тоже есть что то похожее....


 
Кулюкин Олег ©   (2002-11-01 09:05) [5]

В IB я такое делал через хранимые процедуры.
Рекурсия, разумеется.


 
Карелин Артем ©   (2002-11-01 10:06) [6]

У меня такая же хрень.
Я сделал такой финт:
1) чуть изменил TTreeNode /Добавил идентификаторы, по которым я мог бы однозначно идентифицировать узел переменная id у ноды равна идентификатору записи ;)/. Это решило проблему поиска записи в базе, если на разных уровнях дерева и в разных местах могут быть ветки с одинаковым текстом.
2) Рекурсия у меня шла по дереву, а не базе. А в базе простой поиск по папе.
В результате достигнул очень большой скорости...

Пример такой рекурсии был на www.Ibase.ru



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

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

Наверх




Память: 0.48 MB
Время: 0.017 c
3-69155
SpiritS
2002-10-30 15:35
2002.11.21
Работа с компонентами TrichEdit, TdbRichEdit


3-69140
БОБ
2002-10-31 09:29
2002.11.21
SELECT...


1-69335
Дмитрий Баранов
2002-11-11 15:28
2002.11.21
Подключение к событиям IE


3-69114
lmax
2002-11-02 01:19
2002.11.21
Проблема выборки данных с датой


1-69314
RDA
2002-11-12 16:37
2002.11.21
Указатели.