Comment fonctionne un CTE récursif, ligne par ligne
Les CTE récursifs, communément appelés requêtes hiérarchiques, sont utilisés pour parcourir et extraire des informations à partir de structures de données arborescentes. Comprendre comment ces requêtes s'exécutent peut être difficile.
Un CTE récursif fonctionne comme une série d'opérations UNION ALL imbriquées, ressemblant à ce qui suit :
WITH abcd1 AS ( SELECT * FROM @tbl WHERE ParentID IS NULL ) UNION ALL WITH abcd2 AS ( SELECT t.* FROM abcd1 JOIN @tbl t ON t.ParentID = abcd1.id ) UNION ALL WITH abcd3 AS ( SELECT t.* FROM abcd2 JOIN @tbl t ON t.ParentID = abcd2.id ) ...
Chaque itération du bloc membre récursif crée un nouvel ensemble de résultats en joignant l’itération précédente avec la table de base. Ce processus se poursuit jusqu'à ce que la condition d'arrêt soit remplie, déterminée par l'absence de lignes renvoyées.
Dans l'exemple fourni :
Ancre (SELECT... ):
Membre récursif (SELECT ...) :
Calcul du chemin :
Itération (UNION ALL) :
Sélection (SELECT * FROM abcd) :
Il est important de noter que l'ancre n'est pas ignorée dans les itérations suivantes. Au lieu de cela, il sert de point de départ à chaque membre récursif pour explorer la hiérarchie. Pour éviter les doublons dans le résultat final, un identifiant unique (Chemin) est utilisé pour différencier les enregistrements portant le même nom qui existent à différents niveaux de la hiérarchie.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!