![]() |
|
|
|||||||
| Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
![]() |
|
|
Опции темы | Поиск в этой теме | Опции просмотра |
|
|
|
#1
|
|||
|
|||
|
есть список людей, с именами, адресами и т.д.
У каждой записи есть свой ID - генерится сервером (Interbase) У некоторых людей в списке есть "подчинённые" - они получают свой ID, но ещё и номер "главного". В итоге таблица получается "деревом" - у каждого подчинённого могут ещё быть люди в подчинении. Когда выбираем "самого главного" - видим весь список людей. Когда выбираем одного из подчинённых - видим список его подчинённых И подчинённых этого подчинённого. Что не понимаю как сделать - вывести всех подчинённых выбранного подчинённого "вглубь" Может я немонго сумбурно объяснил, наверное, но суть такова - выбрав на 1-м уровне я должен видеть все уровни вглубь (не важно сколько их), выбрав 2-й уровень я должен увидеть всех на 3-м, 4-м и т.д. уровнях. Посмотреть подчинённых без "рекурсии вглубь" - делается на ура и легко, а вот как дальше - не пойму. Пишется всё на Delphi2006 + IB7 |
|
#2
|
|||
|
|||
|
В MS SQL Server 2005 делается с помощью шаблона (CTE - common table expression), который описывается со слова with.
with [recursive] <alias1> [(<список полей>)] as (<Select1>) <Select2> В квадратных скобках необязательные параметры, уголки - для описания (их не будет). В Select2 используется шаблон. Select1 на самом деле содержит два Select'а, соединённых UNION ALL. Первый содержит отправную точку, второй - условие направления (к предкам или потомкам). Ваш пример: Код:
WITH tree(id, data) AS(
SELECT ID, Name
FROM Table1
WHERE (ID=5) -- отправная точка
UNION ALL
SELECT t1.ID, t1.Name
FROM Table1 t1 JOIN
tree ON tree.id = t1.IDParent)
SELECT *
FROM treeПоследний раз редактировалось AlexSku, 22.08.2008 в 13:18. |