在工作中常常会遇到一些数据表包含父子关系的数据,比如行业、地区等等,如果需要将其节点按父子关系一步一步列出来,就需要使用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用法示例

相关文章:

  • 2022-12-23
  • 2021-09-27
  • 2021-05-10
  • 2021-12-09
  • 2022-12-23
  • 2022-02-17
  • 2021-08-12
猜你喜欢
  • 2021-09-03
  • 2021-06-21
  • 2021-05-04
  • 2021-08-28
相关资源
相似解决方案