ORACLE递归查询语法
既然会看ORACLE递归查询那么大家应该是比较清楚递归是什么意思了,在这里我就不多加说明了,只作简单介绍了。
言归正传所谓递归查询那么数据表中数据的结构应该是符合递归查询的基本条件,即表中有ID,PID(节点编号、父节点编号)如果把数据以UI的方式展现出来应该是一棵或多棵树了。
那么我们要以其中一个节点去递归查询出这个节点子节点或父节点的过程就是我们所要说明的。
递归查询语法:
select ... from tablename where 条件4 start with 条件1 connect by 条件2 AND 条件3
|
如下面的表结构:
CREATE
TABLE
SC_DISTRICT
(
IID NUMBER(10)
NOT
NULL
,
PARENT_ID NUMBER(10),
INAME VARCHAR2(255 BYTE)
NOT
NULL
,
BZ NUMBER(4)
);
ALTER
TABLE
SC_DISTRICT
ADD
(
CONSTRAINT
SC_DISTRICT_PK
PRIMARY
KEY
(IID));
ALTER
TABLE
SC_DISTRICT
ADD
(
CONSTRAINT
SC_DISTRICT_R01
FOREIGN
KEY
(PARENT_ID)
REFERENCES
SC_DISTRICT (IID));
INSERT
INTO
SC_DISTRICT(IID,INAME)
VALUES
(1,
'四川省'
);
INSERT
INTO
SC_DISTRICT(IID,PARENT_ID,INAME,BZ)
VALUES
(2,1,
'巴中市'
,0);
INSERT
INTO
SC_DISTRICT(IID,PARENT_ID,INAME,BZ)
VALUES
(3,1,
'达州市'
,0);
INSERT
INTO
SC_DISTRICT(IID,PARENT_ID,INAME,BZ)
VALUES
(4,2,
'巴州区'
,0);
INSERT
INTO
SC_DISTRICT(IID,PARENT_ID,INAME,BZ)
VALUES
(5,2,
'通江县'
,0);
INSERT
INTO
SC_DISTRICT(IID,PARENT_ID,INAME,BZ)
VALUES
(6,2,
'平昌县'
,0);
INSERT
INTO
SC_DISTRICT(IID,PARENT_ID,INAME,BZ)
VALUES
(7,3,
'通川区'
,0);
INSERT
INTO
SC_DISTRICT(IID,PARENT_ID,INAME,BZ)
VALUES
(8,3,
'宣汉县'
,0);
INSERT
INTO
SC_DISTRICT(IID,PARENT_ID,INAME,BZ)
VALUES
(9,8,
'塔河乡'
,1);
INSERT
INTO
SC_DISTRICT(IID,PARENT_ID,INAME,BZ)
VALUES
(10,8,
'三河乡'
,1);
INSERT
INTO
SC_DISTRICT(IID,PARENT_ID,INAME,BZ)
VALUES
(11,8,
'胡家镇'
,1);
INSERT
INTO
SC_DISTRICT(IID,PARENT_ID,INAME,BZ)
VALUES
(12,8,
'南坝镇'
,1);
INSERT
INTO
SC_DISTRICT(IID,PARENT_ID,INAME,BZ)
VALUES
(13,6,
'大寨乡'
,2);
INSERT
INTO
SC_DISTRICT(IID,PARENT_ID,INAME,BZ)
VALUES
(14,6,
'响滩镇'
,2);
INSERT
INTO
SC_DISTRICT(IID,PARENT_ID,INAME,BZ)
VALUES
(15,6,
'龙岗镇'
,2);
INSERT
INTO
SC_DISTRICT(IID,PARENT_ID,INAME,BZ)
VALUES
(16,6,
'白衣镇'
,2);
--查询平昌县的子节点
SELECT
*
FROM
SC_DISTRICT
START
WITH
INAME =
'平昌县'
CONNECT
BY
PRIOR
IID = PARENT_ID
--查询平昌县的父节点
SELECT
*
FROM
SC_DISTRICT
START
WITH
INAME =
'平昌县'
CONNECT
BY
PRIOR
PARENT_ID= IID
--只是过滤节点BZ为0的,但不会过滤掉节点BZ为0的子节点(这点大家注意了),
--当前也有过滤BZ为0的子节点的办法
SELECT
*
FROM
SC_DISTRICT
WHERE
BZ = 0
START
WITH
INAME =
'平昌县'
CONNECT
BY
PRIOR
PARENT_ID= IID
--此方式不仅可以过滤掉BZ为0的节点而且会不再去遍历此节点的子节点
SELECT
*
FROM
SC_DISTRICT START
WITH
INAME =
'平昌县'
CONNECT
BY
PRIOR
PARENT_ID= IID
AND
BZ = 0
--总结:到底是查父节点还是子节点,有级联顺序决定
--规律:【本记录字段】=【连接字段】
--如本实例:是通过本记录的parentid匹配其他记录的aid(主键)结果是查父节点
--如顺序颠倒,则是:有本记录的aid(主键)匹配其他记录的parentid,结果是查子节点
--总结:start with ...connect by prior 递归查询也是对结果过滤,类似where过滤,先于where过滤执行
相关推荐
### Oracle 递归查询详解及实例 #### 一、引言 在数据库查询语言中,Oracle 提供了一种强大的功能——递归查询,这在其他数据库系统如 SQL Server 中是缺失的功能。递归查询允许用户执行多级关联查询,特别适用于...
oracle递归查询
综合以上信息,dhtmlx Tree结合Oracle递归查询提供了一种高效的方法来展示层次结构数据。通过优化数据库查询并减少应用程序中的计算负担,这种方法可以显著提升Web应用的性能。理解如何编写适当的SQL查询以及如何将...
### Oracle递归查询详解 #### 一、引言 在处理具有层级结构的数据时,递归查询是一项非常有用的技能。例如,在处理组织架构、产品分类等数据时,我们经常需要查询某一节点及其所有子节点或者从某个节点追溯到其根...
oracle 递归调用 地区 ,用到的方法是 SYS_CONNECT_BY_PATH,可以扩展层级 名称
### Oracle中的递归查询详解 #### 一、引言 在数据库管理中,处理具有层次结构的数据是一项常见的任务。例如,在组织结构、产品分类或文件系统等场景中,经常需要查询这种类型的层级数据。Oracle数据库提供了强大...
Oracle数据库在处理树形结构数据时提供了强大的递归查询功能,这种特性对于组织结构、产品分类、层级菜单等场景的应用非常广泛。递归树形结构查询主要依赖于`CONNECT BY`和`PRIOR`关键字,它们允许我们构建复杂的...
这里,我们将深入探讨如何使用递归查询来构建菜单树,并特别关注在MySQL和Oracle这两种广泛使用的数据库系统中的实现。 首先,我们要理解什么是递归查询。递归查询是一种在数据库中处理层次数据的方法,它通过自身...
这是Oracle递归查询的关键部分。`connect by`子句定义了层次之间的连接规则。在这里,`prior`关键字用来引用上一层的值,即父节点的`parent_id`应该等于当前行的`id`,这样我们就沿着父到子的方向遍历树。 3. `...
Oracle数据库系统提供了两种主要的递归查询方法:一种是使用`WITH`子句配合`UNION ALL`,另一种是使用`START WITH`和`CONNECT BY`。这两种方法都能解决查询层次关系的问题,例如找出某个节点的所有子节点或父节点。 ...
oracle 如何递归查询父子关系。经常用于构造树结构
在 Oracle 中,递归函数可以使用 CONNECT BY 语句来实现递归查询。CONNECT BY 语句的基本语法如下所示: ```sql SELECT ... FROM ... START WITH ... CONNECT BY ... ``` 其中,`START WITH` 子句指定了递归查询的...
在Oracle数据库中,递归查询是一种强大的工具,用于处理层级数据结构,如组织结构、文件系统或树形关系。在本篇文章中,我们将探讨如何利用递归查询来查找父子兄弟节点,这对于理解和处理这类关系非常关键。 首先,...
Oracle数据库系统在处理层次数据或树形结构时,提供了强大的工具——递归查询。递归查询允许我们在数据表中处理嵌套级别的数据,这在权限查询、组织结构、产品分类等场景中尤其常见。本文将深入探讨Oracle中的树状...
以下是在Oracle中进行递归查询的例子: ```sql SELECT id, name, CONNECT_BY_ROOT id AS root_id FROM employees START WITH id = some_employee_id CONNECT BY PRIOR id = manager_id; ``` 六、注意事项与优化 1....
Oracle数据库中的递归查询是一种强大的工具,用于处理层次结构数据,如组织结构、产品分类或地理区域等。在Oracle中,`START WITH` 和 `CONNECT BY` 是进行递归查询的关键字,它们允许我们从一个特定的根节点出发,...
在Oracle中,对树的递归查询主要依赖于`CONNECT_BY`功能。`CONNECT_BY`是Oracle SQL的一个扩展,用于处理层次查询。它允许我们通过指定的连接条件来遍历层级数据,从而进行递归查询。例如,我们可以用以下方式查询一...
ORACLE、MSSQL(Microsoft SQL Server)、MYSQL是三大主流数据库系统,它们各自提供了不同的方式来实现递归查询。 首先,我们来看ORACLE数据库中的递归查询。ORACLE通过CONNECT BY子句来实现递归查询。CONNECT BY...
MySQL 递归查询是指在 MySQL 中实现类似 Oracle Hierarchical Queries 的功能,用于查询树形结构中的所有子节点。由于 MySQL 目前还没有内置的递归查询功能,因此需要使用其他方法来实现。 第一种方法:使用函数来...