mysql、sql server和oracle递归查询

1.sqlserver:获取本级及下级部门

WITH cte as( 
          select deptId,deptName,superdeptid from ts_cttsp_dept where deptid=(select groups from ts_cttsp_staffInfo where staffNum=#{assignee,jdbcType=VARCHAR})
          union all  
          select s.deptId,s.deptName,s.superdeptid from ts_cttsp_dept  s 
          inner join cte t on s.superdeptid=t.deptId   

          )

select deptid from cte

 

2.oracle 递归

 

现在要递归查询冶炼(id=2)的所有父节点和子节点:

[sql]  view plain  copy
 
  1. SELECT * FROM tree START WITH id = 2 CONNECT BY PRIOR pid = id -- 递归查询父节点  
  2. union  
  3. SELECT * FROM tree START WITH id = 2 CONNECT BY pid = PRIOR id; -- 递归查询子节点  

当然,也可以使用in关键字递归查询多个节点的父节点和子节点:

[sql]  view plain  copy
 
  1. SELECT * FROM tree START WITH id in (1, 10) CONNECT BY PRIOR pid = id -- 递归查询父节点  
  2. union  
  3. SELECT * FROM tree START WITH id in (1, 10) CONNECT BY pid = PRIOR id; -- 递归查询子节点  

 

3.mysql查找所有的父节点

SELECT T2.`USER_ID`,T2.`USERNAME`
FROM ( 
    SELECT 
        @r AS _id, 
        (SELECT @r := IMMEDIATE_SUPERIOR FROM USERS WHERE USER_ID = _id) AS PARENT_ID, 
        @l := @l + 1 AS lvl 
    FROM 
        (SELECT @r := 469912346530152448, @l := "0") vars, 
         USERS h 
    WHERE @r <> 0) T1 
LEFT JOIN USERS T2 
ON T1._id = T2.USER_ID 
WHERE T2.USER_ID != 469912346530152448

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值