start with ... connect by ... prior 实例

创建表的脚本及测试数据
CREATE TABLE TABLE1
(
  UUID VARCHAR2(20 BYTE),
  XUHAO VARCHAR2(20 BYTE),
  PRICE NUMBER(10,2)
)

Insert into TABLE1
  (UUID, XUHAO, PRICE)
 Values
  ('001', '3', 140);
Insert into TABLE1
  (UUID, XUHAO, PRICE)
 Values
  ('002', '3.1', 140);
Insert into TABLE1
  (UUID, XUHAO, PRICE)
 Values
  ('003', '3.1.1', 50);
Insert into TABLE1
  (UUID, XUHAO, PRICE)
 Values
  ('004', '3.1.1.1', 20);
Insert into TABLE1
  (UUID, XUHAO, PRICE)
 Values
  ('005', '3.1.1.2', 30);
Insert into TABLE1
  (UUID, XUHAO, PRICE)
 Values
  ('006', '3.1.2', 90);
Insert into TABLE1
  (UUID, XUHAO, PRICE)
 Values
  ('007', '3.1.2.1', 40);
Insert into TABLE1
  (UUID, XUHAO, PRICE)
 Values
  ('008', '3.1.2.2', 50);
Insert into TABLE1
  (UUID, XUHAO, PRICE)
 Values
  ('009', '4', 136);
Insert into TABLE1
  (UUID, XUHAO, PRICE)
 Values
  ('010', '4.1', 70);
Insert into TABLE1
  (UUID, XUHAO, PRICE)
 Values
  ('011', '4.2', 66);
Insert into TABLE1
  (UUID, XUHAO, PRICE)
 Values
  ('012', '5', 90);
COMMIT;

得到所叶子及没有叶子的节点:

select * from table1 a 
where connect_by_isleaf=1 
start with length(xuhao)=1 
connect by xuhao like prior xuhao||'.%' 
  and xuhao not like prior xuhao||'.%.%' 


 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值