Click here to Skip to main content
12,399,471 members (50,659 online)
Click here to Skip to main content
Add your own
alternative version

Tagged as

Stats

9.1K views
6 bookmarked
Posted

SQL Server Recursive Fetch From Self Referencing Table

, 19 Nov 2009 CPOL
Rate this:
Please Sign up or sign in to vote.
CREATE PROC GetChildNodes (@ID uniqueidentifier)ASBEGINWITH PermissionList (PermissionID, PermissionName, Level)AS(SELECT ap.PermissionID, ap.PermissionName, 0 AS LevelFROM Permission AS apWHERE PermissionID = @IDUNION ALLSELECT ap.PermissionID, ap.PermissionName, Level + 1FROM
CREATE PROC GetChildNodes (@ID uniqueidentifier)
AS
BEGIN
WITH PermissionList (PermissionID, PermissionName, Level)
AS
(
SELECT ap.PermissionID, ap.PermissionName, 0 AS Level
FROM Permission AS ap
WHERE PermissionID = @ID
UNION ALL
SELECT ap.PermissionID, ap.PermissionName, Level + 1
FROM Permission AS ap
INNER JOIN PermissionList AS pl
ON ap.ParentPermissionID = pl.PermissionID
) 

SELECT PermissionID, PermissionName, Level
FROM PermissionList 

END

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

Share

About the Author

Anish M
Web Developer
India India
No Biography provided

You may also be interested in...

Comments and Discussions

 
-- There are no messages in this forum --
| Advertise | Privacy | Terms of Use | Mobile
Web02 | 2.8.160721.1 | Last Updated 19 Nov 2009
Article Copyright 2009 by Anish M
Everything else Copyright © CodeProject, 1999-2016
Layout: fixed | fluid