Dato un id figlio, ho bisogno di restituire una query contenente tutti i genitori di quel bambino così come i loro genitori fino a quando non arrivo al genitore di root. Ad esempio, dato questi dati:Trova in modo ricorsivo tutti gli antenati dato al bambino
ID/Parent ID
1/0
2/1
3/2
4/0
5/3
Quindi, se ho passato in ID 5 Vorrei ottenere una query con i risultati:
ID/Parent ID
1/0
2/1
3/2
In questa tabella non funziona con un tipo hierarchyid così Sospetto che questo dovrà essere fatto con un CTE, ma non ho idea di come. Se può essere fatto in una query/proc SQL, qualsiasi aiuto sarebbe apprezzato.
Grazie
Questo è semplicemente fantastico. L'unico tweak che ho fatto è stato usare la clausola DISTINCT sulla SELECT finale. Non sono preoccupato per le prestazioni a causa dei piccoli recordset con cui lavorerò. Questo filtra i duplicati e restituisce solo le gerarchie che voglio, in base ai criteri che ho inserito nella clausola WHERE della prima query CTE (non usando id = @childId nel mio caso) – bcr