在递归 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中文网其他相关文章!