MySQL stöder inte rekursiva frågor.
Jag skulle föreslå att du tittar på Bill Karwins presentation där han jämför fyra olika modeller för att lagra arvsdata och tittar på deras för- och nackdelar:
- Angränsningslista
- Sökvägsuppräkning
- Inkapslade uppsättningar
- Stängningstabell
Bild 48 visar den relativa svårigheten för vissa typer av frågor med var och en av modellerna. Från din fråga låter det som att du är mest intresserad av "Query subtree", för vilken grannlistan (den modell du använder för närvarande) presterar sämst av de fyra.
Alternativt om du bara vill välja hela trädet, som i all data i tabellen, kan du använda den enkla frågan SELECT * FROM yourtable
och rekonstruera trädstrukturen i klienten.