ORACLE进阶start with connect by 实现递归查询_oracle start with connect by优化
在Oracle中,START WITH
和CONNECT BY
是结合在一起使用的,用于实现递归查询,也就是在层次查询中使用。
以下是一个使用START WITH
和CONNECT BY
实现递归查询的例子:
假设我们有一个组织结构表org
,表中包含org_id
(组织ID)和parent_org_id
(父组织ID)。
CREATE TABLE org (
org_id NUMBER,
parent_org_id NUMBER,
org_name VARCHAR2(50)
);
INSERT INTO org VALUES (1, NULL, '总公司');
INSERT INTO org VALUES (2, 1, '分公司1');
INSERT INTO org VALUES (3, 1, '分公司2');
INSERT INTO org VALUES (4, 2, '分公司2-1');
INSERT INTO org VALUES (5, 3, '分公司2-2');
如果我们想要查询某个特定组织的所有下级组织,可以使用如下的递归查询:
SELECT org_id, org_name
FROM org
START WITH org_id = 1 -- 这里指定了起始节点的ID
CONNECT BY PRIOR org_id = parent_org_id;
这将返回组织ID为1的所有下级组织,包括其所有子孙组织。
如果我们想要查询某个特定组织的所有上级组织,只需要调整START WITH
子句指定的起始节点,并在CONNECT BY
子句中使用PRIOR
来表示上级关系即可:
SELECT org_id, org_name
FROM org
START WITH org_id = 5 -- 这里指定了起始节点的ID
CONNECT BY PRIOR parent_org_id = org_id;
这将返回组织ID为5的所有上级组织,包括其所有父级组织。
评论已关闭