![]() |
|
|
Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
|
Опции темы | Поиск в этой теме | Опции просмотра |
#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. |