Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2002.11.21;
Скачать: [xml.tar.bz2];

Вниз

Хитрый 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;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.46 MB
Время: 0.007 c
1-69321
Step[B.M.]
2002-11-12 16:35
2002.11.21
Как сонсольное приложение сделать невидимым ?


3-69211
oss
2002-11-01 15:26
2002.11.21
вопрос по FireBird у


1-69403
Anar
2002-11-10 21:55
2002.11.21
Событие OnMouseMove


4-69620
REA
2002-10-09 12:02
2002.11.21
Размеры шрифтов


3-69162
Шурик Ш
2002-10-31 13:51
2002.11.21
Календарь под кнопочкой





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский