新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
自己慢慢看:
从网站建设到定制行业解决方案,为提供成都网站设计、网站制作服务体系,各种行业企业客户提供网站建设解决方案,助力业务快速发展。成都创新互联将不断加快创新步伐,提供优质的建站服务。
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;
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中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)
你试试,我没有环境。
查询菜单树指定父节点下的所有子菜单,并按照菜单的排序号在在层级内进行排序
SQL如下
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
假设: 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;