I have a table:
Series ======== ID SeriesName ParentSeriesID
A series can be a "root" series, (ParentSeriesID
is 0 or null) or it can have a Parent. A series can also be several levels down, i.e. its Parent has a Parent, which has a Parent, etc.
How can I query the table to get a Series by it's ID and ALL descendant Series' ?
So far I have tried:
SELECT child.*
FROM Series parent JOIN Series child ON child.ParentSeriesID = parent.ID
WHERE parent.ID = @ParentID
But this only returns the first level of children, I want the parent node, and all "downstream" nodes. I am not sure how to progress from here.
Make use of
CTE
feature avaiable in slq server 2005 onwards for recurisve queryYou can view example over here :
SQL SERVER – Simple Example of Recursive CTE
I just enhance the work of Thomas. If you need to get the depth of the hierarchy and getting the parentid here is the code.
This was almost the same with Thomas' work.
That's all. I know it's too late but I hope anyone who encounter this may help them. Thanks Thomas for the original code. :)
If you are using SQL Server 2005+, you can use common-table expressions
For more:
Recursive Queries Using Common Table Expressions