温馨提示×

怎样在SQL Server中实现递归

小樊
110
2024-07-13 14:59:22
栏目: 云计算

在SQL Server中,可以使用通用表表达式(CTE)来实现递归查询。下面是一个简单的示例,展示如何在SQL Server中使用CTE实现递归查询:

  1. 创建一个包含递归数据的表。
CREATE TABLE Employee
(
    EmployeeID INT PRIMARY KEY,
    Name VARCHAR(50),
    ManagerID INT
);

INSERT INTO Employee VALUES (1, 'Alice', NULL);
INSERT INTO Employee VALUES (2, 'Bob', 1);
INSERT INTO Employee VALUES (3, 'Charlie', 1);
INSERT INTO Employee VALUES (4, 'David', 2);
INSERT INTO Employee VALUES (5, 'Eve', 2);
  1. 使用CTE编写递归查询。
WITH RecursiveCTE AS
(
    SELECT EmployeeID, Name, ManagerID
    FROM Employee
    WHERE ManagerID IS NULL

    UNION ALL

    SELECT e.EmployeeID, e.Name, e.ManagerID
    FROM Employee e
    JOIN RecursiveCTE r ON r.EmployeeID = e.ManagerID
)
SELECT *
FROM RecursiveCTE;

在上面的示例中,我们首先选择顶级经理(ManagerID为NULL的员工),然后通过JOIN操作递归地选择其下属员工。最后,我们选择所有递归的结果并将其输出。

需要注意的是,在编写递归查询时,必须遵守一些规则,比如CTE必须包含UNION ALL语句,以及递归部分必须引用CTE自身。

通过以上步骤,你可以在SQL Server中实现递归查询。

0