I'm experimenting with CTE's in SQL Server but have reached a dead end with getting the following scenario to work. I have a hierarchy table similar to this:
Node(ID:439) Node(ID:123) Node(ID:900) Node(ID:56) Node(ID:900)
NodeID ParentNodeID 439 0 123 439 900 123 56 439 900 56
So basically we have a parent-child hierarchy table, with one subtle difference. Each child could potentially have more then one parent. I have researched many blog articles, and StackOverflow posts, about creating CTE's that return parent-child records, but they don't return all of the parents for the children, just the first one that it finds.
Here's an example CTE that I tried:
WITH Hierarchy(NodeID, ParentNodeID) AS ( SELECT T1.NodeID, T1.ParentNodeID FROM ParentChildTable T1 WHERE T1.NodeID = 439 UNION ALL SELECT T1.NodeID, T1.ParentNodeID FROM Heirarchy T1 INNER JOIN Heirarchy TH ON TH.NodeID = T1.ParentNodeID )
(Note: The names of the tables and columns in the above CTE have been changed from the orginal for privacy purposes.)
The above CTE works fine, it finds all the parent-child records starting from ID:439, but it only finds one parent for item ID:900, even though it has two parents.
Could someone let me know if this is possible using CTE's, or is there another SQL way to do this?