첨부 실행 코드는 나눔고딕코딩 폰트를 사용합니다.
유용한 소스 코드가 있으면 icodebroker@naver.com으로 보내주시면 감사합니다.
블로그 자료는 자유롭게 사용하세요.

■ CTE 재귀 호출 사용하기

----------------------------------------------------------------------------------------------------

WITH CTE(ParentID, ID, Name, DisplayOrder, MenuLevel)

AS

(

    SELECT

        ----------------------------------------

        A.ParentID

       ,A.ID

       ,A.Name

       ,A.DisplayOrder

       ----------------------------------------

       ,1 AS MenuLevel

    FROM Menu AS A

    WHERE A.ParentID = -1

    UNION ALL

    SELECT

        ----------------------------------------

        A.ParentID

       ,A.ID

       ,A.Name

       ,A.DisplayOrder

        ----------------------------------------

       ,B.MenuLevel + 1

    FROM Menu AS A, CTE AS B

    WHERE A.ParentID = B.ID

)

SELECT ParentID, ID, Name, DisplayOrder FROM CTE

ORDER BY MenuLevel;

----------------------------------------------------------------------------------------------------

Posted by 사용자 icodebroker
TAG

댓글을 달아 주세요