• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Oracle 递归查询

mysql 搞代码 4年前 (2022-01-09) 36次浏览 已收录 0个评论

既然会看ORACLE递归查询那么大家应该是比较清楚递归是什么意思了,在这里我就不多加说明了,只作简单介绍了。言归正传所谓递归查

既然会看Oracle递归查询那么大家应该是比较清楚递归是什么意思了,在这里我就不多加说明了,,只作简单介绍了。

言归正传所谓递归查询那么数据表中数据的结构应该是符合递归查询的基本条件,即表中有ID,PID(节点编号、父节点编号)如果把数据以UI的方式展现出来应该是一棵或多棵树了。

那么我们要以其中一个节点去递归查询出这个节点子节点或父节点的过程就是我们所要说明的。

递归查询语法:

如下面的表结构

CREATE TABLE SC_DISTRICT( IIDNUMBER(10)NOT NULL, PARENT_ID NUMBER(10), INAMEVARCHAR2(255 BYTE)NOT NULL, BZ      NUMBER(4)
);
ALTER TABLE SC_DISTRICT ADD ( CONSTRAINT SC_DISTRICT_PK PRIMARY KEY (IID));ALTER TABLE SC_DISTRICT ADD ( CONSTRAINT SC_DISTRICT_R01 FOREIGN KEY (PARENT_ID) REFERENCES SC_DISTRICT (IID));););););););););););););););););

如果如图

–查询平昌县的子节点

SELECT * FROM SC_DISTRICT
START WITH INAME = ‘平昌县’
CONNECT BY PRIOR IID =

本文来源gaodai.ma#com搞##代!^码网(

PARENT_ID

–查询平昌县的父节点

SELECT * FROM SC_DISTRICT
START WITH INAME = ‘平昌县’
CONNECT BY PRIOR PARENT_ID= IID

–只是过滤节点BZ为0的,但不会过滤掉节点BZ为0的子节点(这点大家注意了),

–当前也有过滤BZ为0的子节点的办法

SELECT * FROM SC_DISTRICT WHERE BZ = 0
START WITH INAME = ‘平昌县’
CONNECT BY PRIOR PARENT_ID= IID

–此方式不仅可以过滤掉BZ为0的节点而且会不再去遍历此节点的子节点

SELECT * FROM SC_DISTRICT START WITH INAME = ‘平昌县’
CONNECT BY PRIOR PARENT_ID= IID AND BZ = 0

如果大家对递归的方式比较了解的话上面的几种方式就很容易理解了。


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Oracle 递归查询

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址