您的位置:首页 > 数据库 > Oracle

Oracle中connect by用法示例

2019-02-01 11:34 113 查看

在工作中常常会遇到一些数据表包含父子关系的数据,比如行业、地区等等,如果需要将其节点按父子关系一步一步列出来,就需要使用connect by了。

如有由自身行业代码basecode和父行业代码parentcode构成父子关系的行业表tindustry:

如果想获取“\申万明细行业\农林牧渔\林业”这样详细的行业树,就需要使用如下查询:

[code]SELECT BASECODE, SYS_CONNECT_BY_PATH(BASECODE, '\') AS INDU_CODE,
SYS_CONNECT_BY_PATH(BASENAME, '\') AS INDU_NAME
FROM   TINDUSTRY
START  WITH PARENTCODE IS NULL
CONNECT BY PRIOR BASECODE = PARENTCODE;

 

start with为起始的节点,connect by为父子关系。

查询结果为如下:

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: