Oracle中connect by用法示例

时间:2021-12-24 19:06:42

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

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

Oracle中connect by用法示例

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

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为父子关系。

查询结果为如下:

Oracle中connect by用法示例