oracle 中 递归
select Id,DeptCode,DeptName
from Department www.2cto.com
start with Id = 1
connect by prior Id = ParentDeptId;
start with 表示从哪一行记录开始递归查询,即根节点
connect by 表示进行递归,后面跟递归条件
prior 表示前一条记录,表示上一条记录的Id = 下一条记录的ParentDeptId
比如上面的SQL语句就可以理解为,以Id 为1的记录为根节点,递归查询下一条记录的ParentDeptId = 前一条记录的Id
sqlserver 中递归
with Dep as
(
select Id,DeptCode,DeptName from Department where Id=1
union all
select d.Id,d.DeptCode,d.DeptName from Dep
inner join Department d on dep.Id = d.ParentDeptId
)
select * from Dep
简单解释一下:with as属于sql server新特性CTE(Common Table Expression)的关键字,用来储存临时结果集。常用于代替子查询。本例中可以理解为,找出Id=1的记录后,存放在临时表Dept中,然后临时表和Department进行内连接,找出它的子记录。子记录和第一条记录union后作为Dept新的结果集继续进行内连接,找出新的子记录。
本文详细介绍了SQL递归查询在Oracle和SQL Server中的使用方法,包括递归查询的基本语法、参数说明以及示例代码解析。通过具体的SQL语句展示如何在数据库中进行层次结构的数据查询。

被折叠的 条评论
为什么被折叠?



