1

在一次采访中,面试官问什么是分层查询,我回答了 CTE(公用表表达式),但他说两者都不同,有什么不同?

4

1 回答 1

1

正如 Magnus 指出的,CTE 不需要用于分层查询。它可以用于我们需要临时存储一些数据的任何地方,我们希望在这些数据上执行一些操作,比如应用 RANK() 函数。例如,考虑在nth值列表中查找最大的查询。我们可以通过使用 CTE 简单有效地实现这一点。

例如(无递归):

     WITH CTE AS
        (SELECT *,
        RANK() OVER(ORDER BY Amount DESC) AS GrantRank
        FROM [Grant] )
        SELECT * FROM CTE
        WHERE GrantRank = 3

当然,我们可以使用 CTE 使用递归来实现分层查询。

例如(递归调用):

WITH CTE_EMPLOYEE_HEIRARCHY AS
(
    SELECT E.EmployeeID, E.ReportsTo AS Supervisor, E.FirstName, E.LastName
    FROM EMPLOYEES E WHERE E.EmployeeID = 5

    UNION ALL

    SELECT E1.EmployeeID, E1.ReportsTo AS Supervisor, E1.FirstName, E1.LastName
    FROM CTE_EMPLOYEE_HEIRARCHY 
    JOIN EMPLOYEES E1
    ON E1.ReportsTo = CTE_EMPLOYEE_HEIRARCHY.EmployeeID 

)

SELECT * FROM CTE_EMPLOYEE_HEIRARCHY

参考资料: 1:SQLAuthority 博客 2:代码项目文章

于 2013-05-30T11:59:27.560 回答