oracle怎么树查询,oracle 查询树层级

oracle 如何查询树

自己慢慢看:

从网站建设到定制行业解决方案,为提供成都网站设计、网站制作服务体系,各种行业企业客户提供网站建设解决方案,助力业务快速发展。成都创新互联将不断加快创新步伐,提供优质的建站服务。

1.树结构的描述

树结构的数据存放在表中,数据之间的层次关系即父子关系,通过表中的列与列间的关系来描述,如emp 表中的empno 和mgr 。empno 表示该雇员的编号,mgr 表示该雇员对应的领导的编号,即子节点的empno 值等于父节点的mgr 值。在表的每一行中都有一个表示父节点的mgr (除根节点外),通过每个节点的父节点,就可以确定整个树结构。

在SELECT 语句中使用START WITH 和CONNECT BY子句可以查询表中的树型结构关系。其语法如下:

SELECT语句

[START WITH]

CONNECT BY {PRIOR 列名1 = 列名2| 列名1 = PRIOR 列名2};

其中:CONNECT BY 子句说明每行数据将是按层次顺序检索,并规定将表中的数据连入树型结构的关系中。PRIORY 运算符必须放置在连接关系的两列中某一个的前面。对于节点间的父子关系,PRIOR 运算符所在的列表示该列是父节点,相应的另一列则表示子节点,从而确定查找树结构是的顺序是自顶向下还是自底向上。在连接关系中,除了可以使用列名外,还允许使用列表达式。START WITH 子句为可选项,用来标识哪个节点作为查找树型结构的根节点。若该子句被省略,则表示所有满足查询条件的行作为根节点。

START WITH选项:不但可以指定一个根节点,还可以指定多个根节点。

例3:

SELECT * FROM EMP

START WITH EMPNO=7369 OR EMPNO = 7521

CONNECT BY PRIOR MGR = EMPNO;

上述查询语句,从根节点empno = 7369或empno = 7521开始查询雇员编号和对应的领导编号的关系,得到两个根节点

2.关于PRIOR

运算符PRIOR 被放置于等号前后的位置,决定着查询时的检索顺序。

PRIOR 被置于CONNECT BY 子句中等号的前面时,则强制从根节点到叶节点的顺序检索,即由父节点向子节点方向通过树结构,我们称之为自顶向下的方式。如:

CONNECT BY PRIOR EMPNO=MGR

PIROR 运算符被置于CONNECT BY 子句中等号的后面时,则强制从叶节点到根节点的顺序检索,即由子节点向父节点方向通过树结构,我们称之为自底向上的方式。例如:

CONNECT BY EMPNO=PRIOR MGR

在这种方式中也应指定一个开始的节点。

3.定义查找起始节点

在自顶向下查询树结构时,不但可以从根节点开始,还可以定义任何节点为起始节点,以此开始向下查找。这样查找的结果就是以该节点为开始的结构树的一枝。

4.使用LEVEL

在具有树结构的表中,每一行数据都是树结构中的一个节点,由于节点所处的层次位置不同,所以每行记录都可以有一个层号。层号根据节点与根节点的距离确定。不论从哪个节点开始,该起始根节点的层号始终为1 ,根节点的子节点为2 ,依此类推。

5.节点和分支的裁剪

在对树结构进行查询时,可以去掉表中的某些行,也可以剪掉树中的一个分支,使用WHERE 子句来限定树型结构中的单个节点,以去掉树中的单个节点,但它却不影响其后代节点(自顶向下检索时)或前辈节点(自底向顶检索时),如上例2。

6.排序显示

如同在其它查询中一样,在树结构查询中也可以使用ORDER BY 子句,改变查询结果的显示顺序,而不必按照遍历树结构的顺序。

例4

SELECT * FROM EMP

START WITH EMPNO=7902

CONNECT BY PRIOR MGR = EMPNO

ORDER BY empno ASC;

oracle树型结构查询

CREATE TABLE test_tree ( test_id INT NOT NULL, pid INT, test_val VARCHAR(10), PRIMARY KEY (test_id) );

INSERT INTO test_tree VALUES(1, NULL, '.NET '); INSERT INTO test_tree VALUES(2, 1, 'C#'); INSERT INTO test_tree VALUES(3, 1, 'J#'); INSERT INTO test_tree VALUES(4, 1, 'ASP.NET' ); INSERT INTO test_tree VALUES(5, 1, 'VB.NET');

INSERT INTO test_tree VALUES(6, NULL, 'J2EE' ); INSERT INTO test_tree VALUES(7, 6, 'EJB'); INSERT INTO test_tree VALUES(8, 6, 'Servlet'); INSERT INTO test_tree VALUES(9, 6, 'JSP');

INSERT INTO test_tree VALUES(10, NULL, 'Dat abase'); INSERT INTO test_tree VALUES(11, 10, 'DB2'); INSERT INTO test_tree VALUES(12, 10, 'MySQ L'); INSERT INTO test_tree VALUES(13, 10, 'Oracl e'); INSERT INTO test_tree VALUES(14, 10, 'SQL S erver');

INSERT INTO test_tree VALUES(15, 13, 'PL/SQ L'); INSERT INTO test_tree VALUES(16, 15, 'Functi on'); INSERT INTO test_tree VALUES(17, 15, 'Proce dure'); INSERT INTO test_tree VALUES(18, 15, 'Packa ge'); INSERT INTO test_tree VALUES(19, 15, 'Curso r');

INSERT INTO test_tree VALUES(20, 14, 'T-SQL' );

使用 START WITH CONNECT BY 语句实现树状 查询

SQL ed Wrote file afiedt.buf

1 SELECT 2 LPAD(' ', 2*(LEVEL-1)) || test_val AS test_va l 3 FROM 4 test_tree 5 START WITH 6 test_id IN (1, 6, 10) 7* CONNECT BY PRIOR test_id = pid SQL /

TEST_VAL -----------------------------------------------------------

.NET C# J# ASP.NET VB.NET J2EE EJB Servlet JSP Database DB2

TEST_VAL -----------------------------------------------------------

MySQL Oracle PL/SQL Function Procedure Package Cursor SQL Server T-SQL

CREATE TABLE test_tree ( test_id INT NOT NULL, pid INT, test_val VARCHAR(10), PRIMARY KEY (test_id) );

INSERT INTO test_tree VALUES(1, NULL, '.NET '); INSERT INTO test_tree VALUES(2, 1, 'C#'); INSERT INTO test_tree VALUES(3, 1, 'J#'); INSERT INTO test_tree VALUES(4, 1, 'ASP.NET' ); INSERT INTO test_tree VALUES(5, 1, 'VB.NET');

INSERT INTO test_tree VALUES(6, NULL, 'J2EE' ); INSERT INTO test_tree VALUES(7, 6, 'EJB'); INSERT INTO test_tree VALUES(8, 6, 'Servlet'); INSERT INTO test_tree VALUES(9, 6, 'JSP');

INSERT INTO test_tree VALUES(10, NULL, 'Dat abase'); INSERT INTO test_tree VALUES(11, 10, 'DB2'); INSERT INTO test_tree VALUES(12, 10, 'MySQ L'); INSERT INTO test_tree VALUES(13, 10, 'Oracl e'); INSERT INTO test_tree VALUES(14, 10, 'SQL S erver');

INSERT INTO test_tree VALUES(15, 13, 'PL/SQ L'); INSERT INTO test_tree VALUES(16, 15, 'Functi on'); INSERT INTO test_tree VALUES(17, 15, 'Proce dure'); INSERT INTO test_tree VALUES(18, 15, 'Packa ge'); INSERT INTO test_tree VALUES(19, 15, 'Curso r');

INSERT INTO test_tree VALUES(20, 14, 'T-SQL' );

使用 START WITH CONNECT BY 语句实现树状 查询

SQL ed Wrote file afiedt.buf

1 SELECT 2 LPAD(' ', 2*(LEVEL-1)) || test_val AS test_va l 3 FROM 4 test_tree 5 START WITH 6 test_id IN (1, 6, 10) 7* CONNECT BY PRIOR test_id = pid SQL /

TEST_VAL -----------------------------------------------------------

.NET C# J# ASP.NET VB.NET J2EE EJB Servlet JSP Database DB2

TEST_VAL -----------------------------------------------------------

MySQL Oracle PL/SQL Function Procedure Package Cursor SQL Server T-SQL

20 rows selected.

20 rows selected

oracle 树查询问题

相关介绍:

在oracle中start with connect by (prior) 用来对树形结构的数据进行查询。其中start with conditon 给出的是数据搜索范围, connect by后面给出了递归查询的条件,prior 关键字表示父数据,prior 条件表示子数据需要满足父数据的什么条件。

思路:列出所有子,然后判断所列出的子下面再没有子了

select * from (

select ID, parentid from tb start with id='B' connect by prior parentid = id

union

select ID, parentid from tb start with id='G' connect by prior parentid = id ) A

where not exsits ( select 1 from tb b where A.id= B. parentid)

你试试,我没有环境。

oracle 树型结构查询并排序

查询菜单树指定父节点下的所有子菜单,并按照菜单的排序号在在层级内进行排序

SQL如下

Oracle递归查询:使用prior实现树操作

select * from tableName

start with  条件A   -- 开始递归的根节点,可多个条件

connect  by prior  条件B  -- prior  决定查询的索引顺序

where 条件 C

select t.empno,t.mgr,t.deptno ,level

from emp t

connect by prior t.empno=t.mgr

order by level,t.mgr,t.deptno;

找到empno为7369的所有领导。

select t.*,t.rowid from emp t

start with t.empno = 7369       --从empno为7369的开始查找

connect by prior t.mgr = t.empno ;    --上一条数据(这里就是empno为7369)的mgr == 当前遍历这一条数据的empno(那么就会找到empno为7902的用户)

找到empno为7566的所有下属

select t.*,t.rowid from emp t

start with t.empno = 7566

connect by prior t.empno = t.mgr ; --注意:connect by  t.mgr =prior t.empno与左边写法含义一样

start with :设置起点,省略后默认以全部行为起点。

connect by [condition] :与一般的条件一样作用于当前列,但是在满足条件后,会以全部列作为下一层级递归(没有其他条件的话)。

prior : 表示上一层级的标识符。经常用来对下一层级的数据进行限制。不可以接伪列。

level :伪列,表示当前深度。

connect_by_root() :显示根节点列。经常用来分组。

connect_by_isleaf :1是叶子节点,0不是叶子节点。在制作树状表格时必用关键字。

sys_connect_by_path() :将递归过程中的列进行拼接。

nocycle , connect_by_iscycle : 在有循环结构的查询中使用。

siblings : 保留树状结构,对兄弟节点进行排序

;request_id=162538763316780265474850biz_id=0utm_medium=distribute.pc_search_result.none-task-blog-2~all~first_rank_v2~rank_v29-22-52652111.first_rank_v2_pc_rank_v29_1utm_term=ORACLE%E9%80%92%E5%BD%92%E5%87%BD%E6%95%B0spm=1018.2226.3001.4187

;request_id=162538763316780269872688biz_id=0utm_medium=distribute.pc_search_result.none-task-blog-2~all~baidu_landing_v2~default-5-108683534.first_rank_v2_pc_rank_v29_1utm_term=ORACLE%E9%80%92%E5%BD%92%E5%87%BD%E6%95%B0spm=1018.2226.3001.4187

;request_id=162538763316780265474850biz_id=0utm_medium=distribute.pc_search_result.none-task-blog-2~all~first_rank_v2~rank_v29-10-105773226.first_rank_v2_pc_rank_v29_1utm_term=ORACLE%E9%80%92%E5%BD%92%E5%87%BD%E6%95%B0spm=1018.2226.3001.4187

ORACLE 树数据查询

假设: test_tree 是树结构表, test_usetree是使用了树节点的表

select a.name from test_tree a

where a.treeid in (select b.treeid from test_usetree b )

START WITH treeid = 'A01'

CONNECT BY PRIOR treeid = ptreeid;


本文标题:oracle怎么树查询,oracle 查询树层级
新闻来源:http://hbruida.cn/article/phsgcp.html