怎么在Oracle中实现递归树形结构查询功能

73次阅读
没有评论

共计 14998 个字符,预计需要花费 38 分钟才能阅读完成。

自动写代码机器人,免费开通

这篇文章给大家介绍怎么在 Oracle 中实现递归树形结构查询功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

oracle 树状结构查询即层次递归查询,是 sql 语句经常用到的,在实际开发中组织结构实现及其层次化实现功能也是经常遇到的。

概要:树状结构通常由根节点、父节点、子节点和叶节点组成,简单来说,一张表中存在两个字段,dept_id,par_dept_id, 那么通过找到每一条记录的父级 id 即可形成一个树状结构,也就是 par_dept_id(子)=dept_id(父),通俗的说就是这条记录的 par_dept_id 是另外一条记录也就是父级的 dept_id,其树状结构层级查询的基本语法是:

SELECT [LEVEL],*
 FEOM table_name
 START WITH  条件 1
 CONNECT BY PRIOR  条件 2
 WHERE  条件 3
 ORDER BY 排序字段 

说明:LEVEL— 伪列,用于表示树的层次

条件 1 — 根节点的限定条件,当然也可以放宽权限,以获得多个根节点,也就是获取多个树

条件 2 — 连接条件,目的就是给出父子之间的关系是什么,根据这个关系进行递归查询

条件 3 — 过滤条件,对所有返回的记录进行过滤。

排序字段 — 对所有返回记录进行排序

对 prior 说明:要的时候有两种写法:connect by prior dept_id=par_dept_id 或 connect by dept_id=prior par_dept_id,前一种写法表示采用自上而下的搜索方式(先找父节点然后找子节点),后一种写法表示采用自下而上的搜索方式(先找叶子节点然后找父节点)。

树状结构层次化查询需要对树结构的每一个节点进行访问并且不能重复,其访问步骤为:

怎么在 Oracle 中实现递归树形结构查询功能怎么在 Oracle 中实现递归树形结构查询功能

大致意思就是扫描整个树结构的过程即遍历树的过程,其用语言描述就是:

步骤一:从根节点开始;

步骤二:访问该节点;

步骤三:判断该节点有无未被访问的子节点,若有,则转向它最左侧的未被访问的子节,并执行第二步,否则执行第四步;

步骤四:若该节点为根节点,则访问完毕,否则执行第五步;

步骤五:返回到该节点的父节点,并执行第三步骤。

除此之外,sys_connect_by_path 函数是和 connect by 一起使用的,在实战中具体带目的具体介绍!

实战:最近做项目的组织结构,对于部门的各级层次显示,由于这部分掌握不牢固,用最笨的 like 模糊查询解决了,虽然功能实现了,但是问题很多,如扩展性不好,稍微改下需求就要进行大改,不满意最后对其进行了优化。在开发中能用数据库解决的就不要用 java 去解决,这也是我一直保持的想法并坚持着。

创建表:

create table SYS_DEPT 
 ( dept_id VARCHAR2(32) not null,
 dept_name VARCHAR2(128),
 dept_code VARCHAR2(32),
 par_dept_id VARCHAR2(32),
 dept_leader VARCHAR2(32),
 dept_desc VARCHAR2(256),
 create_time CHAR(19),
 org_id VARCHAR2(32),
 dept_type VARCHAR2(1),
 order_id NUMBER,
 state CHAR(1) default  1 ,
 bqq_dept_id VARCHAR2(128),
 bqq_par_dept_id VARCHAR2(128)
 )
 -- Add comments to the table
 comment on table SYS_DEPT
 is  部门信息,和单位多对一 
 -- Add comments to the columns
 comment on column SYS_DEPT.dept_id
 is  主键 
 comment on column SYS_DEPT.dept_name
 is  名称 
 comment on column SYS_DEPT.dept_code
 is  编码,用于递归 
 comment on column SYS_DEPT.par_dept_id
 is  父级部门 ID 
 comment on column SYS_DEPT.dept_leader
 is  部门领导 ID 
 comment on column SYS_DEPT.dept_desc
 is  部门描述 
 comment on column SYS_DEPT.create_time
 is  yyyy-mm-dd HHMMSS 
 comment on column SYS_DEPT.org_id
 is  单位 ID 
 comment on column SYS_DEPT.dept_type
 is  1:正式部门;2:虚拟部门(用于通讯录展示) comment on column SYS_DEPT.order_id
 is  排序字段 
 comment on column SYS_DEPT.state
 is  0:无效;1:有效 
 comment on column SYS_DEPT.bqq_dept_id
 is  企业 qqdeptid 
 comment on column SYS_DEPT.bqq_par_dept_id
 is  企业 qq 父类 deptid

插入测试数据:

undefined

insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (40288ac45a3c1e8b015a3c28b4ae01d6 ,  客运部 ,  110 ,  -1 , null, null,  2017-02-14 182625 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 29,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b60f98a1d59b3 ,  综合室 ,  110001 ,  40288ac45a3c1e8b015a3c28b4ae01d6 , null, null,  2017-04-12 150338 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 63,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b6134d9ff2946 ,  生产调度 ,  110001001 ,  4028e4d35b5ca4ee015b60f98a1d59b3 , null, null,  2017-04-12 160825 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 135,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b60f9fae95a44 ,  站务中心 ,  110002 ,  40288ac45a3c1e8b015a3c28b4ae01d6 , null, null,  2017-04-12 150407 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 64,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b613562be2a08 ,  东岗站 ,  110002001 ,  4028e4d35b5ca4ee015b60f9fae95a44 , null, null,  2017-04-12 160900 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 136,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b6135f9de2aca ,  焦家湾站 ,  110002002 ,  4028e4d35b5ca4ee015b60f9fae95a44 , null, null,  2017-04-12 160939 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 137,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b6136a3e22bb2 ,  拱星墩站 ,  110002003 ,  4028e4d35b5ca4ee015b60f9fae95a44 , null, null,  2017-04-12 161022 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 138,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b613723bb2c5f ,  省气象局站 ,  110002004 ,  4028e4d35b5ca4ee015b60f9fae95a44 , null, null,  2017-04-12 161055 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 139,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b6137a5772d06 ,  五里铺站 ,  110002005 ,  4028e4d35b5ca4ee015b60f9fae95a44 , null, null,  2017-04-12 161128 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 140,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b6137e4e72d57 ,  兰州大学站 ,  110002006 ,  4028e4d35b5ca4ee015b60f9fae95a44 , null, null,  2017-04-12 161144 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 141,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b613840112dd0 ,  东方红广场站 ,  110002007 ,  4028e4d35b5ca4ee015b60f9fae95a44 , null, null,  2017-04-12 161208 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 142,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b6138765c2e12 ,  省政府站 ,  110002008 ,  4028e4d35b5ca4ee015b60f9fae95a44 , null, null,  2017-04-12 161221 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 143,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b6138b84b2e68 ,  西关站 ,  110002009 ,  4028e4d35b5ca4ee015b60f9fae95a44 , null, null,  2017-04-12 161238 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 145,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b6139390e2f06 ,  文化宫站 ,  110002010 ,  4028e4d35b5ca4ee015b60f9fae95a44 , null, null,  2017-04-12 161311 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 146,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b613980a82f61 ,  小西湖站 ,  110002011 ,  4028e4d35b5ca4ee015b60f9fae95a44 , null, null,  2017-04-12 161330 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 147,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b6139c1dc2fb4 ,  七里河站 ,  110002012 ,  4028e4d35b5ca4ee015b60f9fae95a44 , null, null,  2017-04-12 161346 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 148,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b613a24853047 ,  西站十字站 ,  110002013 ,  4028e4d35b5ca4ee015b60f9fae95a44 , null, null,  2017-04-12 161412 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 149,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b613a81f030ce ,  兰州西站北广场站 ,  110002014 ,  4028e4d35b5ca4ee015b60f9fae95a44 , null, null,  2017-04-12 161436 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 150,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b613ad627313d ,  土门墩站 ,  110002015 ,  4028e4d35b5ca4ee015b60f9fae95a44 , null, null,  2017-04-12 161457 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 151,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b613b394c31c6 ,  马滩站 ,  110002016 ,  4028e4d35b5ca4ee015b60f9fae95a44 , null, null,  2017-04-12 161522 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 152,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b613b9051325e ,  兰州海关站 ,  110002017 ,  4028e4d35b5ca4ee015b60f9fae95a44 , null, null,  2017-04-12 161545 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 153,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b613c286b332e ,  兰州城市学院(省科技馆)站 ,  110002018 ,  4028e4d35b5ca4ee015b60f9fae95a44 , null, null,  2017-04-12 161624 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 154,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b613c806933a3 ,  深安大桥南站 ,  110002019 ,  4028e4d35b5ca4ee015b60f9fae95a44 , null, null,  2017-04-12 161646 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 155,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b613cdf98342c ,  陈官营站 ,  110002020 ,  4028e4d35b5ca4ee015b60f9fae95a44 , null, null,  2017-04-12 161711 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 157,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b60fa3e2f5a94 ,  乘务中心 ,  110003 ,  40288ac45a3c1e8b015a3c28b4ae01d6 , null, null,  2017-04-12 150424 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 65,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b613d738d34f4 ,  陈官营车场组 ,  110003001 ,  4028e4d35b5ca4ee015b60fa3e2f5a94 , null, null,  2017-04-12 161748 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 158,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b613defed359e ,  东岗车场组 ,  110003002 ,  4028e4d35b5ca4ee015b60fa3e2f5a94 , null, null,  2017-04-12 161820 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 159,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b613e42ae3612 ,  第一车队 ,  110003003 ,  4028e4d35b5ca4ee015b60fa3e2f5a94 , null, null,  2017-04-12 161841 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 161,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b613e7a50366c ,  第二车队 ,  110003004 ,  4028e4d35b5ca4ee015b60fa3e2f5a94 , null, null,  2017-04-12 161856 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 162,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b613ebc8e36c1 ,  第三车队 ,  110003005 ,  4028e4d35b5ca4ee015b60fa3e2f5a94 , null, null,  2017-04-12 161913 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 163,  1 , null, null);
insert into SYS_DEPT (DEPT_ID, DEPT_NAME, DEPT_CODE, PAR_DEPT_ID, DEPT_LEADER, DEPT_DESC, CREATE_TIME, ORG_ID, DEPT_TYPE, ORDER_ID, STATE, BQQ_DEPT_ID, BQQ_PAR_DEPT_ID)
values (4028e4d35b5ca4ee015b613eff483729 ,  第四车队 ,  110003006 ,  4028e4d35b5ca4ee015b60fa3e2f5a94 , null, null,  2017-04-12 161930 ,  402881e54c40d74d014c40d8407a0016 ,  1 , 164,  1 , null, null);

在这张表中有三个字段:dept_id 部门主键 id;dept_name 部门名称;dept_code 部门编码;par_dept_id 父级部门 id(首级部门为 -1); 当前节点遍历子节点(遍历当前部门下所有子部门包括本身)

select t.dept_id, t.dept_name, t.dept_code, t.par_dept_id, level 
 from SYS_DEPT t 
 start with t.dept_id =  40288ac45a3c1e8b015a3c28b4ae01d6  
 connect by prior t.dept_id = t.par_dept_id 
 order by level, t.dept_code

结果:

dept_id=40288ac45a3c1e8b015a3c28b4ae01d6 是客运部主键,对其下的所有子部门进行遍历,同时用 order by level,dept_code 进行排序 以便达到实际生活中想要的数据;共 31 条数据,部分数据如图所示:

怎么在 Oracle 中实现递归树形结构查询功能

但是:

有问题啊,如果你想在上面的数据中获取层级在 2 也就是 level= 2 的所有部门,发现刚开始的时候介绍的语言不起作用?并且会报 ORA-00933:sql 命令未正确结束,why?

这个我暂时也没有得到研究出理论知识,但是改变下 where level= 2 的位置发现才会可以的。错误的和正确的 sql 我们对比一下,以后会用就行,要是路过的大神知道为什么,还请告知下,万分感谢!

错误 sql:

select t.dept_id, t.dept_name, t.dept_code, t.par_dept_id, level 
 from SYS_DEPT t 
 start with t.dept_id =  40288ac45a3c1e8b015a3c28b4ae01d6  
 connect by prior t.dept_id = t.par_dept_id 
 where level =  2  
 order by level, t.dept_code

正确 sql:

select t.dept_id, t.dept_name, t.dept_code, t.par_dept_id, level 
 from SYS_DEPT t 
 where level =  2  
 start with t.dept_id =  40288ac45a3c1e8b015a3c28b4ae01d6  
 connect by prior t.dept_id = t.par_dept_id 
 order by level, t.dept_code

undefined

怎么在 Oracle 中实现递归树形结构查询功能
当然了,这个对其他形式的 where 过滤所有返回记录没有影响的,这个只是一个例外!

sys_connect_by_path 函数求父节点到子节点路径

简单介绍下,在 oracle 中 sys_connect_by_path 与 connect by 一起使用,也就是先要有或建立一棵树,否则无用还会报错。它的主要作用体现在 path 上即路径,是可以吧一个父节点下的所有节点通过某个字符区分,然后链接在一个列中显示。

sys_connect_by_path(column,clear), 其中 column 是字符型或能自动转换成字符型的列名,它的主要目的就是将父节点到当前节点的“path”按照指定的模式出现,char 可以是单字符也可以是多字符,但不能使用列值中包含的字符,而且这个参数必须是常量,且不允许使用绑定变量,clear 不要用逗号。
文字容易让人疲劳,放图和代码吧

select sys_connect_by_path(t.dept_name, --),t.dept_id, t.dept_name, t.dept_code, t.par_dept_id, level 
 from SYS_DEPT t 
 start with t.dept_id =  40288ac45a3c1e8b015a3c28b4ae01d6  
 connect by prior t.dept_id = t.par_dept_id 
 order by level, t.dept_code

结果:

怎么在 Oracle 中实现递归树形结构查询功能

下面以最简单的情况进行示例说明:

SELECT t.f_id, SYS_CONNECT_BY_PATH(t.f_id,  \) AS con_code,
 SYS_CONNECT_BY_PATH(t.f_name,  \) AS con_name
FROM  表名  t
START WITH t.f_pid IS NULL 
CONNECT BY PRIOR t.f_id = t.f_pid;

关于怎么在 Oracle 中实现递归树形结构查询功能就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计14998字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)