首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >层次查询与公用表表达式(Cte)的区别

层次查询与公用表表达式(Cte)的区别
EN

Stack Overflow用户
提问于 2013-05-30 19:00:30
回答 1查看 256关注 0票数 1

在一次面试中,面试官问什么是分层查询,我回答了CTE (Common table expression ),但他说两者是不同的,有什么不同?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-05-30 19:59:28

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

Eg(无递归):

代码语言:javascript
复制
     WITH CTE AS
        (SELECT *,
        RANK() OVER(ORDER BY Amount DESC) AS GrantRank
        FROM [Grant] )
        SELECT * FROM CTE
        WHERE GrantRank = 3

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

Eg(递归调用):

代码语言:javascript
复制
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

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16834412

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档