SQL Server中使用递归公共表表达式(CTE)的自引用查询
简介
在关系数据库中,自引用查询是一种强大的技术,用于遍历单个表中的层次关系。SQL Server为此目的提供了公共表表达式(CTE),从而实现高效且表达力强的递归查询。
问题
考虑一个简化的“类别”表,其中包含ID、名称和ParentId列。该表支持类别的不确定层次结构,如下面的示例所示:
<code>Id Name ParentId 1 Business NULL 2 Laptops 1 3 Asus 2</code>
目标是构造一个查询,该查询不仅检索指定的类别(例如,“商务笔记本电脑”),而且还提供其所有父类别的逗号分隔列表。
解决方案:递归CTE
为了解决这个问题,可以使用递归CTE。最外层的CTE定义递归的起点,而递归项定义扩展层次结构的逻辑:
<code>WITH CTE AS ( SELECT Id, Name, Name AS Path, ParentId FROM Categories WHERE ParentId IS NULL UNION ALL SELECT t.Id, t.Name, cast(cte.Path + ',' + t.Name as varchar(100)), t.ParentId FROM Categories t INNER JOIN CTE ON t.ParentId = CTE.Id )</code>
查询
为了检索指定的类别及其父类别,我们使用一个简单的查询:
<code>SELECT Id, Name, Path FROM CTE WHERE Name = 'Business Laptops'</code>
结果
查询返回以下结果:
<code>Id Name Path 2 Laptops Business,Laptops</code>
在此示例中,“商务笔记本电脑”是“笔记本电脑”的子项,“笔记本电脑”是“商务”的子项。“路径”列提供了返回根类别的完整层次路径。
结论
SQL Server中的递归CTE提供了一种优雅且高效的方法来导航表中的层次关系。通过利用递归的强大功能,可以构造复杂的查询以从层次数据结构中提取有价值的见解。
以上是SQL Server 中的递归 CTE 如何检索类别及其祖先路径?的详细内容。更多信息请关注PHP中文网其他相关文章!