Maison >base de données >tutoriel mysql >Comment une auto-jointure récursive dans SQL Server peut-elle être utilisée pour récupérer une hiérarchie d'employés ?

Comment une auto-jointure récursive dans SQL Server peut-elle être utilisée pour récupérer une hiérarchie d'employés ?

Susan Sarandon
Susan Sarandonoriginal
2025-01-17 15:26:08336parcourir

How Can a Recursive Self-Join in SQL Server Be Used to Retrieve an Employee Hierarchy?

Auto-jointure récursive SQL Server pour la hiérarchie des employés

Une auto-jointure récursive dans SQL Server est une technique puissante pour naviguer dans les structures de données hiérarchiques. Illustrons cela à l'aide d'une table d'employés où chaque employé possède un identifiant unique et l'identifiant de son superviseur :

Exemple de tableau des employés :

<code>| EmployeeID | Name       | ManagerID |
|------------|------------|------------|
| 1          | John Doe   | NULL       |
| 2          | Jane Smith | 1          |
| 3          | Mary Jones | 2          |
| 4          | Bob Johnson| 3          |</code>

Le défi :

Notre objectif est de récupérer la hiérarchie complète des employés sous un responsable spécifique (par exemple, John Doe). Une auto-jointure récursive fournit une solution élégante.

La solution :

Nous pouvons y parvenir en utilisant l'instruction WITH (Common Table Expression ou CTE) :

<code class="language-sql">WITH EmployeeHierarchy AS (
  SELECT
    EmployeeID,
    Name,
    ManagerID
  FROM
    employees
  WHERE
    ManagerID IS NULL  -- Start with the top-level employee (no manager)
  UNION ALL
  SELECT
    e.EmployeeID,
    e.Name,
    e.ManagerID
  FROM
    employees e
  JOIN
    EmployeeHierarchy q
    ON e.ManagerID = q.EmployeeID  -- Recursively join to itself
)
SELECT
  *
FROM
  EmployeeHierarchy;</code>

Cette requête commence par l'employé racine (pas de manager) et joint récursivement la table employees au CTE (EmployeeHierarchy), en élargissant la hiérarchie niveau par niveau jusqu'à ce que tous les subordonnés soient inclus.

Maintenir l'ordre hiérarchique :

Pour maintenir l'ordre hiérarchique correct, nous pouvons améliorer la requête :

<code class="language-sql">WITH EmployeeHierarchy AS (
  SELECT
    EmployeeID,
    Name,
    ManagerID,
    CAST(ROW_NUMBER() OVER (ORDER BY EmployeeID) AS VARCHAR(MAX)) AS HierarchyPath
  FROM
    employees
  WHERE
    ManagerID IS NULL
  UNION ALL
  SELECT
    e.EmployeeID,
    e.Name,
    e.ManagerID,
    q.HierarchyPath + '.' + CAST(ROW_NUMBER() OVER (PARTITION BY e.ManagerID ORDER BY e.EmployeeID) AS VARCHAR(MAX))
  FROM
    employees e
  JOIN
    EmployeeHierarchy q
    ON e.ManagerID = q.EmployeeID
)
SELECT
  *
FROM
  EmployeeHierarchy
ORDER BY
  HierarchyPath;</code>

Cette requête améliorée ajoute une colonne HierarchyPath, créant un chemin unique pour chaque employé, garantissant ainsi un tri hiérarchique approprié dans le résultat final. La fonction ROW_NUMBER() et la concaténation de chaînes maintiennent les relations parent-enfant.

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn