oracle中用start with...connect by prior子句实现递归查询[例子不错]

原创 2012年03月28日 14:34:19

  今天在做权限这一块,碰到要读取oracle中的树形结构,所以就用到了start with...connect by prior。所以留个脚印以后碰到可以看看。

 

  在oracle中的select语句可以用start with...connect by prior子句实现递归查询,connect by 是结构化查询中用到的,其基本语法是:

//如果只用connect by 而不加 prior 查找的将是 level 为1的一级。
select ... from tablename start with cond1 
connect by prior cond2 
where cond3; 

这里的where是不能加的,我一加一个where就报 sql命令未正确结束的错误。如果有人可以加上去使用,那也请高手我下吧。本人先谢谢了。

不过可以先写 where 然后使用 connect by prior  例如:select * from Sysfunction where nodetype='4' start with parentid ='123'(值) connect by prior functionid=parentid order by level(关键字:级别),parentid, funorder;

简单说来是将一个树状结构存储在一张表里,比如一个表中存在两个字段: 
id,parentid那么通过表示每一条记录的parent是谁,就可以形成一个树状结构。 

用上述语法的查询可以取得这棵树的所有记录。 

其中cond1 是根结点的限定语句,当然可以放宽限定条件,以取得多个根结点,实际就是多棵树。 

cond2是连接条件,其中用prior表示上一条记录,比如 connect by prior id=parentid就是说上一条记录的ID是本条记录的parentid,即本记录的父亲是上一条记录。 
cond3是过滤条件,用于对返回的所有记录进行过滤。 

对于oracle进行简单树查询(递归查询) 
deptid      paredeptid   name 
number    number        char (40 Byte) 
部门id 父部门id(所属部门id) 部门名称 
通过子节点向根节点追朔.

 

复习一下:start with ...connect by 的用法, start with 后面所跟的就是就是递归的种子。 

递归的种子也就是递归开始的地方 connect by 后面的"prior" 如果缺省:则只能查询到符合条件的起始行,并不进行递归查询; 

connect by prior 后面所放的字段是有关系的,它指明了查询的方向。

 

下面看下几个例子:


create table automobiles(
       part_id number(5)
         constraint pk_auto_part_id primary key,
       parent_id number(5)
         constraint fk_auto_ppid_ references  automobiles(part_id),
       part_cname varchar2(30) not null,
       part_ename varchar2(30) not null,
       mp_cost number(9,2),
       desribe varchar2(20)    
);

--插入数据
insert into automobiles values( 1,null,'汽车','mobile',84321.99,'Assembly');
insert into automobiles values( 2,1,'车身','bodywork',19892.99,'Manufacture');
insert into automobiles values( 3,1,'发送机','engine',42128,'Purchase');
insert into automobiles values( 4,1,'附件','attached',15212,'Assembly');
insert into automobiles values( 5,2,'保险杠','bumper',4812.95,'Purchase');
insert into automobiles values( 6,2,'底盘','chassis',12795.11,'Manufacture');
insert into automobiles values( 7,2,'行李箱','Boot',812.11,'Manufacture');
--分层sql脚本语句练习
select level,part_id,parent_id,part_cname,part_ename,mp_cost,desribe
from automobiles
start with part_id=1
connect by prior part_id=parent_id 
order by level;
--缩进显示
select level,
    lpad(' ',2*level-1)||part_cname||' '||part_ename as partName
from automobiles
start with part_id=1
connect by prior part_id=parent_id
order by level;
--使用子查询  当然也可以在from中加入条件来达到子查询的效果
select level,lpad(' ',2*level-1)||part_cname||' '||part_ename as partName from automobiles
start with part_id=(select part_id from automobiles where part_cname like '%轴%')
connect by prior  part_id=parent_id
order by level;
--自底向上的遍历
select level,lpad(' ',2*level-1)||part_cname||' '||part_ename as partName
from automobiles
start with part_id=(select part_id from automobiles where part_cname like '%轴%')
connect by prior parent_id=part_id
order by level;
--删除指定的节点
select level,lpad(' ',2*level-1)||part_cname||' '||part_ename as partName from automobiles
where part_cname <> '底盘'
start with part_id=1
connect by prior parent_id=part_id
order by level;
--删除分支
select level,lpad(' ',2*level-1)||part_cname||' '||part_ename as partName from automobiles
start with part_id=1
connect by prior parent_id=part_id and part_cname <> '底盘'
order by level;

ORACLE--Connect By、Level、Start With的使用(Hierarchical query-层次查询)

查找员工编号为7369的领导: 1 SELECT LEVEL,E.* FROM EMP E CONNECT BY PRIOR E.MGR = E.EMPNO START WITH E.EMPN...
  • piaoxuan1987
  • piaoxuan1987
  • 2013年01月31日 18:24
  • 7919

ORACLE查询树型关系(start with connect by prior)

oracle中的select语句可以用START WITH...CONNECT BY PRIOR子句实现递归查询,connect by 是结构化查询中用到的,其基本语法是: select * from...
  • amork
  • amork
  • 2009年07月20日 16:36
  • 8657

oracle中 sql语句:start with .. connect by prior.. 用法

见:http://blog.csdn.net/tzbiao/article/details/8632031 又见:http://blog.csdn.net/tzbiao/article/details...
  • u011314442
  • u011314442
  • 2016年10月26日 17:43
  • 5524

Oracle高级篇之start with关键字的用法

Oracle高级篇之start with关键字的用法 一,基本语法 SELECT ... FROM    + 表名 START WITH         + 条件1 CONNECT ...
  • reggergdsg
  • reggergdsg
  • 2016年11月06日 18:26
  • 6347

oracle数据库startwith用法

  • 2015年02月18日 15:57
  • 4KB
  • 下载

Oracle 树查询 性能优化纪实(start with, connect by)

在项目中做权限控制时,需要用组织阶层来控制能够访问的数据, 比如A组织的人可以看到其下属组织的人员数据,或者只有A组织是B组织上级的时候才有看B组织人员数据的权利。 根据需求需要构筑DB的表结构,...
  • congqing2011
  • congqing2011
  • 2011年04月22日 11:52
  • 851

Oracle中start with…connect by prior子句用法

Oracle中start with…connect by prior子句用法 connect by 是结构化查询中用到的,其基本语法是: select … from tablename ...
  • qq_35494342
  • qq_35494342
  • 2017年12月29日 09:26
  • 112

oracle中用start with...connect by prior子句实现递归查询[例子不错]

今天在做权限这一块,碰到要读取oracle中的树形结构,所以就用到了start with...connect by prior。所以留个脚印以后碰到可以看看。     在oracle中的s...
  • m13666368773
  • m13666368773
  • 2012年03月28日 14:34
  • 11692

mysql的逆袭:如何做oracle的start with connect by prior递归层次查询

mysql的逆袭:如何做递归层次查询   最近在做一个从oracle数据库到mysql数据库的移植,遇到一个这样的问题        在Oracle 中我们知道有一个 Hi...
  • liwenbluesky
  • liwenbluesky
  • 2015年01月30日 15:42
  • 6765

oracle中用START WITH...CONNECT BY PRIOR子句实现递归查询

oracle中用START WITH...CONNECT BY PRIOR子句实现递归查询今天发现在oracle中的select语句可以用START WITH...CONNECT BY PRIOR子句...
  • qiaopengfei2762
  • qiaopengfei2762
  • 2009年10月18日 10:03
  • 240
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:oracle中用start with...connect by prior子句实现递归查询[例子不错]
举报原因:
原因补充:

(最多只允许输入30个字)