Oracle中connect by用法示例

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

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

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

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

查询结果为如下:

posted @ 2019-02-01 11:35  微笑xwz  阅读(10720)  评论(0编辑  收藏  举报