首页 > 数据库 > mysql教程 > 如何解决SQL Server递归CTE中的最大递归错误?

如何解决SQL Server递归CTE中的最大递归错误?

Patricia Arquette
发布: 2025-01-10 06:02:40
原创
126 人浏览过

How to Solve SQL Server's Max Recursion Error in Recursive CTEs?

在递归 CTE 中克服 SQL Server 递归限制

在 SQL Server 中使用递归公用表表达式 (CTE) 时,您可能会遇到可怕的“超出最大递归深度”错误。当您的嵌套递归查询超过数据库的预定义限制时,就会发生这种情况。

解决方案涉及使用maxrecursion选项:

以下是修改查询以解决此问题的方法:

<code class="language-sql">WITH EmployeeHierarchy AS (
    SELECT 
        EMP_SRC_ID_NR AS Id, USR_ACV_DIR_ID_TE AS Uuid, 
        ISNULL(Employees.APV_MGR_EMP_ID, '0') AS ApprovalManagerId 
    FROM 
        dbo.[tEmployees] AS Employees WITH (NOLOCK)
    WHERE 
        APV_MGR_EMP_ID = @Id 
        AND Employees.APV_MGR_EMP_ID IS NOT NULL 
        AND Employees.EMP_SRC_ID_NR IS NOT NULL  

    UNION ALL

    SELECT 
        EMP_SRC_ID_NR AS Id, USR_ACV_DIR_ID_TE AS Uuid, 
        ISNULL(Employees.UPS_ACP_EMP_NR, '1') AS ApprovalManagerId 
    FROM 
        dbo.[tEmployees] AS Employees WITH (NOLOCK)
    WHERE 
        UPS_ACP_EMP_NR = @Id 
        AND Employees.APV_MGR_EMP_ID IS NOT NULL 
        AND Employees.EMP_SRC_ID_NR IS NOT NULL  

    UNION ALL

    SELECT 
        Employees.EMP_SRC_ID_NR, Employees.USR_ACV_DIR_ID_TE, 
        ISNULL(Employees.APV_MGR_EMP_ID, '2')  
    FROM 
        dbo.[tEmployees] AS Employees WITH (NOLOCK)
    JOIN 
        EmployeeHierarchy ON Employees.APV_MGR_EMP_ID = EmployeeHierarchy.Id 
    WHERE  
        Employees.APV_MGR_EMP_ID IS NOT NULL 
        AND Employees.EMP_SRC_ID_NR IS NOT NULL             
)
SELECT 
    Id AS EmployeeId, 
    Uuid AS EmployeeUuid, 
    ApprovalManagerId AS ManagerId 
FROM EmployeeHierarchy
OPTION (MAXRECURSION 0);</code>
登录后复制

通过附加OPTION (MAXRECURSION 0),您可以有效地消除递归限制,从而允许查询无限期地运行。 不过,使用MAXRECURSION 0时要小心。确保您的 CTE 逻辑正确,以防止可能导致性能问题或崩溃的无限循环。如果递归深度出乎意料地大,请考虑替代方法。 使用 ISNULL 代替 CASE 可以简化代码并提高可读性。

以上是如何解决SQL Server递归CTE中的最大递归错误?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板