Oracle start with 存储树状结构

本文详细解析了Oracle中的STARTWITH和CONNECTBYPRIOR关键字在创建和查询分层表结构(如树状数据)时的用法,包括不同连接条件下的查询示例,以及如何利用它们实现递归查询和层级数据获取。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

建表语句

create table priortest
(
  id   NUMBER not null,
  fatherid NUMBER,
  name      varchar2(4000) not null
);

insert into priortest (ID, FATHERID, NAME)
values ('1000', null, '一级分组');

insert into priortest (ID, FATHERID, NAME)
values ('1001', '1000', '二级分组');

insert into priortest (ID, FATHERID, NAME)
values ('1002', '1001', '三级分组');

insert into priortest (ID, FATHERID, NAME)
values ('1003', '1002', 'water1003');

insert into priortest (ID, FATHERID, NAME)
values ('1004', '1000', '二级分组');

insert into priortest (ID, FATHERID, NAME)
values ('1005', '1000', '二级分组');

insert into priortest (ID, FATHERID, NAME)
values ('1006', '1005', '三级分组');

insert into priortest (ID, FATHERID, NAME)
values ('1007', '1006', 'water1007');

insert into priortest (ID, FATHERID, NAME)
values ('1008', '1006', 'water1008');

insert into priortest (ID, FATHERID, NAME)
values ('1009', '1006', 'water1009');

查询结果

SELECT *
  FROM priortest
 start with id = 1000
connect by prior id = fatherid; --可以取到从这个id开始递归到的所有数据

SELECT *
  FROM priortest
 start with id = 1000
connect by id = prior fatherid; --仅能取到最顶层数据

SELECT *
  FROM priortest
 start with id = 1000
connect by prior fatherid = id; --仅能取到最顶层数据

SELECT *
  FROM priortest
 start with fatherid = 1000
connect by prior id = fatherid; --除了顶层数据取不到

SELECT *
  FROM priortest
 start with fatherid = 1000
connect by prior fatherid = id; --会取到重复数据

基本语法

SELECT ... FROM    + 表名 
START WITH         + 条件1
CONNECT BY PRIOR   + 条件2
WHERE              + 条件3
  1. CONNECT BY PRIOR是结构化查询中用到的;
  2. START WITH… CONNECT BY PRIOR…的作用,简单来说,就是将一个树状结构存储在一张表里。
条件1:是根节点的限定语句,当然可以放宽限定条件,以取得多个根节点,也就是多棵树;在连接关系中,除了可以使用列名外,还允许使用列表达式。
START WITH 子句为可选项,用来标识哪个节点作为查找树形结构的根节点。若该子句省略,则表示所有满足查询条件的行作为根节点。

条件2:是连接条件,其中用PRIOR表示上一条记录,例如connect by prior id = fatherid,意思就是上一条记录的id是本条记录
的fatherid,即本记录的父亲是上一条记录。CONNECT BY子句说明每行数据将是按照层次顺序检索,并规定将表中的数据连入树形结构的关系中。
PRIOR运算符必须放置在连接关系的2列中某一个的前面。对于节点间的父子关系,PRIOR运算符在一侧表示父节点,在另一侧表示子节点,从而确定查
找树结构的顺序是自顶向下,还是自底向上。

条件3:是过滤条件,用于对返回的记录进行过滤。

资料参考

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值