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

Вниз

Уважаемые спецы! Помогите пожалуйста с рекурсивным запросом.   Найти похожие ветки 

 
hgreg   (2002-10-02 12:14) [0]

Есть таблица типа

ID (int)
Title (varchar)
ParentID (int) - ссылка на ID

То есть в таблице хранится дерево.
Нужно сделать запрос, на вход которого подается ID, а на выходе я получаю рекордсет со всеми детьми, внуками, правнуками и т.д.

Заранее благодарен.


 
Prooksius ©   (2002-10-02 12:15) [1]

www.ibase.ru


 
3JIA9I CyKA ©   (2002-10-02 12:39) [2]

Критично использовать рекурсию?


 
hgreg   (2002-10-02 12:40) [3]

Совершенно не критично - мне нужно чтоб оно работало :)


 
Delirium ©   (2002-10-02 13:02) [4]

Развёртка простого дерева

set nocount on
select * into #tmp from test where id=3
while exists(select * from test
where (Parentid in (select id from #tmp))
and (id not in (select id from #tmp)))
insert #tmp select * from test
where (Parentid in (select id from #tmp))
and (id not in (select id from #tmp))
select * from #tmp
drop table #tmp


 
hgreg   (2002-10-02 13:56) [5]

Огромное спасибо - пришлось кое что поправить - но все получилось :)


 
Desdechado ©   (2002-10-02 14:52) [6]

рекурсия в IB, например, ограничена (точно не помню, по-моему 16)


 
Prooksius ©   (2002-10-02 15:20) [7]

Цитирую Data Definition Guide:

Note Stored procedures can be nested up to 1,000 levels deep. This limitation helps to prevent infinite loops that can occur when a recursive procedure provides no absolute terminating condition. Nested procedure calls can be restricted to fewer than 1,000 levels by memory and stack limitations of the server.

По-русски - до 1000 вложений.


 
vuk ©   (2002-10-02 16:06) [8]

Добавлю немного к тому, что писал Delirium.

Если используете MSSQL 2000, можно развертку делать в таблицу-переменную. Оно быстрее будет.


 
SergSuper   (2002-10-03 11:03) [9]

>Prooksius & Desdechado
Вобще-то в MS SQL рекурсия ограничена 32 вызовами. Но в решении, которое привёл Delirium, они всё равно не нужны.

>vuk
Хоть и MS рекомендует везде где это возможно использовать таблицы-переменные, на практике ускорения от их использования не получается. Во всяком случае я не обнаружил. Иногда даже медленне немного.
Т.е. использовать их надо, но ждать что оно будет быстрее работать не стоит.


 
Prooksius ©   (2002-10-03 11:05) [10]

2 SergSuper (03.10.02 11:03)
Это у нас маленький оффтопик - про Interbase вам рассказали :)


 
Desdechado ©   (2002-10-03 13:56) [11]

2 Prooksius © (02.10.02 15:20)
в шестерке - да (как оказалось), а пару лет назад я читал хелп по ИБ5.5 - вот в памяти и задержалось. А может быть это был даже информикс, тогда с ним тоже работал.
короче, оффтопик явный :)



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

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

Наверх




Память: 0.49 MB
Время: 0.02 c
4-78722
Molochai
2002-09-11 09:17
2002.10.24
Задания принтера(как отследить)


7-78696
cdaDmitriy
2002-08-15 15:12
2002.10.24
TRAY


1-78466
LaResistance
2002-10-12 00:46
2002.10.24
Помогите, люди! Глюк в мей проге!


3-78239
brestmarket
2002-10-01 01:44
2002.10.24
Проблема при сжатии ADO-database при помощи JetEngine.CompactData


1-78413
Дмитрий К.К.
2002-10-15 12:14
2002.10.24
External exception