分层查询和公用表表达式(cte)之间的区别

时间:2013-05-30 11:00:30

标签: sql sql-server sql-server-2008

在采访中,采访者询问我回答CTE的层次结构查询是什么 (共表表达)但他说两者都不同 有什么不同?

1 个答案:

答案 0 :(得分: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 Blog              2:Code Project Article