oracle中的select语
句可以用START WITH...CONNECT BY PRIOR子句实现递归查询,connect by 是结构化查询中用到的,其基本语法是:
select ... from
<TableName>
where
<Conditional-1>
start with
<Conditional-2>
connect by
<Conditional-3>
;
<Conditional-
1>:过滤条件,用于对返回的所有记录进行过滤。
<Conditional-
2>:查询结果重起始根结点的限定条件。
<Conditional-
3>:连接条件
数据组织结构如下图:
|---a------a1
| |------a2
|
|---b------b1
|------b2
数据库表结构如下:
create table
t2(
root_id number,
id number,
name
varchar(5),
description varchar(10)
);
insert into
t2(root_id,id,name,description) values(0,1,'a','aaa');
insert into t2(root_id,id,name,description)
values(1,2,'a1','aaa1');
insert into
t2(root_id,id,name,description) values(1,3,'a2','aaa2');
insert into t2(root_id,id,name,description)
values(0,4,'b','bbb');
insert into
t2(root_id,id,name,description) values(4,5,'b1','bbb1');
insert into t2(root_id,id,name,description)
values(4,6,'b2','bbb2');
SQL> select *
from t2;
ROOT_ID ID NAME DESCRIPTIO
----------
---------- ----- ----------
0 1 a aaa
1 2 a1 aaa1
1 3 a2 aaa2
0 4 b bbb
4 5 b1 bbb1
4 6 b2 bbb2
获取完整树:
select
* from t2 start with root_id = 0 connect by prior id = root_id;
|---a------a1
| |------a2
|
|---b------b1
|------b2
ROOT_ID ID NAME DESCRIPTIO
----------
---------- ----- ----------
0 1 a aaa
1 2 a1 aaa1
1 3 a2 aaa2
0 4 b bbb
4 5 b1 bbb1
4 6 b2 bbb2
获取特定子树:
select
* from t2 start with id = 1 connect by prior id = root_id;
|---a------a1
| |------a2
ROOT_ID ID NAME
DESCRIPTIO
---------- ---------- -----
----------
0 1 a
aaa
1 2 a1 aaa1
1 3 a2 aaa2
select
* from t2 start with id = 4 connect by prior id = root_id;
|---b------b1
|------b2
ROOT_ID ID NAME DESCRIPTIO
----------
---------- ----- ----------
0 4 b bbb
4 5 b1 bbb1
4 6 b2 bbb2
如果connect by prior中的prior被省略,则查询将不进行深层递归。
如:
select * from
t2 start with root_id = 0 connect by id = root_id;
|---a
|
|
|---b
ROOT_ID ID NAME DESCRIPTIO
---------- ---------- ----- ----------
0 1 a aaa
0 4 b bbb
如:
select * from t2 start with id = 1 connect
by id = root_id;
|---a
ROOT_ID ID NAME DESCRIPTIO
----------
---------- ----- ----------
0 1 a aaa
原文地址:http://hi.baidu.com/learnfordba/blog/item/28fe4608fcb2112d6a60fbdb.html
分享到:
相关推荐
本文章详细介绍了Oracle中connect by...start with...的用法。
Connect By 可以列出上下级关系 构造序列 求排列组合 逆转求出下上级的关系路径
Oracle数据库中的`CONNECT BY PRIOR`是一个强大的查询构造器,用于处理树形数据结构,尤其在组织层级、部门结构或者员工管理系统中非常常见。这个功能允许我们从一个或多个根节点开始,按照指定的规则遍历整个树结构...
通过本文,我们详细介绍了Oracle数据库中 `START WITH` 和 `CONNECT BY` 的使用方法以及应用场景。这两个关键字对于处理具有层级结构的数据非常有用。此外,我们还讨论了如何利用 `LEVEL` 关键字来显示节点所在的...
文章中给出了一个名为`t_test_connectby`的数据表例子,其中包含父子关系的节点数据。通过该表,我们可以更直观地了解Connect By的执行过程。 - 不指定起始条件时,使用`CONNECT BY`: ```sql SELECT * FROM t_test...
Oracle数据库中的`connect by prior`是一个强大的SQL查询构造,用于处理具有层级关系的数据,常见于组织结构、部门层级、时间序列分析等场景。这个特性允许我们遍历和查询树形结构,将层次数据平展为一行一列的形式...
下面将详细阐述`CONNECT BY`的使用方法、原理以及一些常见的应用场景。 1. **基本语法** `CONNECT BY` 的基本语法如下: ```sql SELECT column1, column2, ... FROM table_name START WITH condition1 CONNECT BY ...
"Connect By的使用探索" Connect By是一种递归查询语句,用于实现树形结构的查询和遍历。它是 Oracle 数据库中的一种特色语句,能够高效地查询树形结构的数据。 Connect By的基本语法 Connect By语句的基本语法...
`START WITH...CONNECT BY PRIOR`是Oracle SQL中的一个特性,用于处理具有层级关系的数据。这个子句允许我们遍历和查询具有父子关系的数据,例如部门和其下属子部门,或者员工和他们的上级经理。 1. **START WITH...
### Oracle中的START WITH CONNECT BY PRIOR 用法详解 #### 一、概念介绍 在Oracle数据库中,`START WITH` 和 `CONNECT BY PRIOR` 是两个非常强大的特性,主要用于处理具有层级结构的数据。这两个特性可以帮助我们...
Oracle的`CONNECT BY`和分析函数是数据库查询中的两种强大工具,主要用于处理复杂的数据结构和进行高级数据分析。本文将深入探讨这两种技术。 ### Oracle `CONNECT BY` 用法总结 `CONNECT BY` 是Oracle SQL中用于...
此问题通常是由于 PL/SQL Developer 的配置不当或者使用的 Oracle 客户端版本较低,不支持 `Connect By` 功能。 #### 三、解决步骤 本文将详细介绍如何解决以上问题,并提供了一键解决方法,即通过下载并正确配置 ...
connect by:connect by是必须的,start with有些情况是可以省略的,或者直接start with 1=1不加限制 prior:prior关键字可以放在等号的前面,也可以放在等号的后面,表示的意义是不一样的,比如 prior id = pid,...
CONNECT BY 的用法可以形成一个树状结构,目前只有 Oracle 支持,其他数据库都要结合存储过程实现。 语法结构为:SELECT * FROM some_table [WHERE 条件 1] CONNECT BY [条件 2] START WITH [条件 3]; 其中,...
行列转换,层级关系,oracle sys_connect_by_path的用法
首先,要查看当前Oracle数据库中的用户连接,你可以使用以下SQL查询: ```sql SELECT username, sid, serial#, status FROM v$session WHERE username <> '1'; ``` 这个查询会返回所有登录用户(除了名为'1'的...
在 Oracle 中,使用 `CONNECT BY` 查询可以很容易地找出特定员工的所有直接和间接下属。例如,要找出 ‘Goyal’ 的所有下属,可以使用以下查询: ```sql SELECT empid, name FROM emp START WITH name = 'Goyal' ...
本文将详细介绍如何在Oracle中使用递归查询,并通过具体的示例来展示其用法。 #### 二、递归查询的基础概念 递归查询是Oracle中一种特殊的查询方式,主要用于检索具有层次结构的数据。在Oracle中实现递归查询需要...
在Oracle数据库中,递归查询可以通过`START WITH CONNECT BY PRIOR`语句实现。此语句允许用户按照树状结构来检索数据。 ##### 1. `START WITH CONNECT BY PRIOR`用法详解 **基本语法**: ```sql SELECT * FROM ...