oracle start with connect by递归查询

通过子节点向根节点追朔.

select * from test start with tid=2 connect by prior fatherid=tid

通过根节点遍历子节点(不包含根节点).

select * from test start with fatherid=0 connect by prior tid=fatherid

通过根节点遍历子节点(包含根节点).

select * from test start with tid=0 connect by prior tid=fatherid

可通过level 关键字查询所在层次.

select a.*,level from test a start with fatherid=0 connect by prior tid=fatherid

备注:
start with ...connect by 的用法, start with 后面所跟的就是就是递归的种子。
递归的种子也就是递归开始的地方 connect by 后面的"prior" 如果缺省:则只能查询到符合条件的起始行,并不进行递归查询;
connect by prior 后面所放的字段是有关系的,它指明了查询的方向。prior 后跟父id就往根节点方向遍历,prior后跟子节点id就往子节点方向遍历。

生活不止眼前的苟且,还有明天和后天的苟且!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值