Вопрос

У меня есть таблица БД с родительскими и дочерними отношениями:

NodeId    NodeName    ParentId
------------------------------
1         Node1       0
2         Node2       0
3         Node3       1
4         Node4       1
5         Node5       3
6         Node6       5
7         Node7       2

Здесь родительский идентификатор = 0 означает, что это узел корневого уровня.Теперь я хочу написать SQL-запрос, который будет возвращать дочерний элемент на всех уровнях родительской категории.

напримердля nodeId = 1 он должен вернуть 3, 4, 5, 6.

Я использую MS SQL Server 2005.

Это было полезно?

Решение

with [CTE] as (
    select * from [TheTable] c where c.[ParentId] = 1
    union all
    select * from [CTE] p, [TheTable] c where c.[ParentId] = p.[NodeId]
)
select * from [CTE]

Другие советы

Вам следует изучить возможность использования модели вложенных множеств для отношений родитель-потомок в базе данных SQL.Это намного удобнее, чем пытаться сохранить родительский идентификатор записей в такой таблице, и значительно упрощает выполнение подобных запросов.

И просто чтобы убедиться, что он работает, если он является родителем самого себя (в противном случае он будет рекурсивно работать, пока не сломается):

   with [CTE] as (
        select * from [TheTable] c where c.[ParentId] = 1
        union all
        select * from [CTE] p, [TheTable] c where c.[ParentId] = p.[NodeId]
        and c.[ParentId] <> c.[NodeId]
    )
    select * from [CTE]
 WITH Temp_Menu AS
 ( 
  SELECT AM.* from FCB_AccessMenu AM where AM.[ParentId] = 6   

           UNION ALL     

        SELECT AM.* FROM  FCB_AccessMenu AM ,Temp_Menu TM  WHERE AM.[ParentID]=TM.[MenuID]        

  )   

  SELECT * FROM Temp_Menu ORDER BY ParentID
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top