【Oracle】Start With关键字

6 篇文章 0 订阅
1 篇文章 0 订阅

1.start with关键字作用

适用于树状数据-层级查询!

2.Demo

create table DEMO ( ID varchar2(20) primary key, NAME varchar2(100), PID varchar2(10) )

--插入几条数据
//校长级别
Insert Into DEMO values ('001', '校长', '-1');

//老师级别
Insert Into DEMO values ('011', '张老师', '001');

Insert Into DEMO values ('012', '宋老师', '001');

Insert Into DEMO values ('013', '刘老师', '001');

//班级
Insert Into DEMO values ('101', '一班', '011'); 

nsert Into DEMO values ('102', '二班', '011');

Insert Into DEMO values ('103', '三班', '012');

Insert Into DEMO values ('103', '四班', '013');

3.使用start with 关键字

(1)基本语法

	SELECT ... FROM + 表名
	
	WHERE + 条件3
	
	START WITH + 条件1
	
	CONNECT BY PRIOR + 条件2

条件1:表示数据的切入点,也就是第一条数据从哪里开始.
条件2:是连接条件,其中用PRIOR表示上一条记录,例如CONNECT BY PRIOR ID = PID,意思就是上一条记录的ID是本条记录的PID
条件3:表示条件1和条件2,执行遍历结果之后再进行条件约束

重点关注条件1和条件2即可!

(2)Demo数据执行

SELECT * FROM DEMO start with id = '001' Connect By Prior id = pid

//以上SQL分析:
//表示切入点,也就是我的第一条数据
start with id = '001' 

//表示上一条数据的id是当前数据的pid(如果不是就表明不是当前节点)
Connect By Prior id = pid 

反之,以班级查上级结构:

//上一条记录的PID是本条记录的ID
SELECT * FROM start_demo start with id = '103' Connect By Prior PID = id 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值