Показать сообщение отдельно
  #2  
Старый 22.08.2008, 13:13
AlexSku AlexSku вне форума
Специалист
 
Регистрация: 07.05.2007
Адрес: Москва
Сообщения: 884
Репутация: 21699
По умолчанию

В 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
Может, где ошибся - сейчас нет возможности проверить.
Ответить с цитированием