Mysql && Oracle 递归查询,树形结构查询 WITH RECURSIVE 、START WITH语句

递归查询

mysql8.0

WITH RECURSIVE
-- 查询id为3 及其 子节点
WITH RECURSIVE temp AS
(
  SELECT c.* from city c where c.id = 3
  UNION ALL
  SELECT c.* from city c,temp where c.parent_id = temp.id
)
SELECT * FROM temp;
-- 查询id为11 及其 父节点
WITH RECURSIVE temp AS
(
  SELECT c.* from city c where c.id = 11
  UNION ALL
  SELECT c.* from city c,temp where c.id = temp.parent_id
)
SELECT * FROM temp;
-- 如果不需要节点本身,则在后增加 id != 3
-- 如果是查子节点时不需要本身,可以修改 c.id = 3 改为 c.parent_id = 3  或者

Oracle

start with
-- 查询id为3 及其 子节点
SELECT
	t.ID,
	t.NAME 
FROM
	CITY t START WITH t.ID = 3 CONNECT BY PRIOR t.ID = t.PARENT_ID
-- 查询id为11 及其 父节点 (仅调换了PRIOR 后两个字段的位置)
SELECT
	t.ID,
	t.NAME 
FROM
	CITY t START WITH t.ID = 11 CONNECT BY PRIOR t.PARENT_ID = t.ID
-- 查询id为3 的 子节点 (不包含本身,把t.ID换成t.PARENT_ID)
SELECT
	t.ID,
	t.NAME 
FROM
	CITY t START WITH t.PARENT_ID = 3 CONNECT BY PRIOR t.ID = t.PARENT_ID
-- 查询id为3 的 父节点 (不包含本身,结果:3和3的父节点会重复)
SELECT
	t.ID,
	t.NAME 
FROM
	CITY t START WITH t.PARENT_ID = 3 CONNECT BY PRIOR t.PARENT_ID = t.ID
PRIOR 在子节点前 表示向子节点查询
PRIOR 在父节点前 表示向父节点查询	
START WITH 后跟着子节点 表示查出来 包含自己
START WITH 后跟着父节点 表示查出来 不包含自己

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值