SYS_CONNECT_BY_PATH 学习_zhwsh's space

来源:百度文库 编辑:神马文学网 时间:2024/05/05 11:18:12
查看文章   http://hi.baidu.com/zhwsh163/blog     SYS_CONNECT_BY_PATH 学习2008-09-08 10:59

SELECT ename
FROM scott.emp
START WITH ename = 'KING'
CONNECT BY PRIOR empno = mgr;
得到结果为:KING
JONES
SCOTT
ADAMS
FORD
SMITH
BLAKE
ALLEN
WARD
MARTIN
TURNER
JAMES

而:SELECT SYS_CONNECT_BY_PATH(ename, '>') "Path"
FROM scott.emp
START WITH ename = 'KING'
CONNECT BY PRIOR empno = mgr;

得到结果为:>KING
>KING>JONES
>KING>JONES>SCOTT
>KING>JONES>SCOTT>ADAMS
>KING>JONES>FORD
>KING>JONES>FORD>SMITH
>KING>BLAKE
>KING>BLAKE>ALLEN
>KING>BLAKE>WARD
>KING>BLAKE>MARTIN
>KING>BLAKE>TURNER
>KING>BLAKE>JAMES
>KING>CLARK
>KING>CLARK>MILLER

其实SYS_CONNECT_BY_PATH这个函数是oracle9i才新提出来的!
它一定要和connect by子句合用!
第一个参数是形成树形式的字段,第二个参数是父级和其子级分隔显示用的分隔符!

START WITH 代表你要开始遍历的的节点,
CONNECT BY PRIOR 是标示父子关系的对应!

如下例子:select max(
substr(
sys_connect_by_path(column_name,',')
,2)
)
from (select column_name,rownum rn from user_tab_columns where table_name ='AA_TEST')
start with rn=1 connect by rn=rownum ;

是将列用,进行分割成为一行,然后将首个,去掉,只取取最大的那个数据。

---------

下面是别人的例子:

1、带层次关系

SQL> create table dept(deptno number,deptname varchar2(20),mgrno number);

Table created.

SQL> insert into dept values(1,'总公司',null);

1 row created.

SQL> insert into dept values(2,'浙江分公司',1);

1 row created.

SQL> insert into dept values(3,'杭州分公司',2);

1 row created.

SQL> commit;

Commit complete.

SQL> select max(substr(sys_connect_by_path(deptname,','),2)) from dept connect by prior deptno=mgrno;

MAX(SUBSTR(SYS_CONNECT_BY_PATH(DEPTNAME,','),2))
--------------------------------------------------------------------------------
总公司,浙江分公司,杭州分公司

2、行列转换
如把一个表的所有列连成一行,用逗号分隔:

SQL> select max(substr(sys_connect_by_path(column_name,','),2))
from (select column_name,rownum rn from user_tab_columns where table_name ='DEPT')
start with rn=1 connect by rn=rownum ;

MAX(SUBSTR(SYS_CONNECT_BY_PATH(COLUMN_NAME,','),2))
--------------------------------------------------------------------------------
DEPTNO,DEPTNAME,MGRNO

SYS_CONNECT_BY_PATH 学习_zhwsh's space SYS_CONNECT_BY_PATH 学习_zhwsh's space Master_qiang‘s space 正确理解正式学习与非正式学习 - Qin Yu's Space - 在线教育资讯 在线教... 博客园 - Terrylee‘s Tech Space - Enterprise Library2.0(1):Data Access Application Block学习 Castle ActiveRecord学习实践(4):实现One-Many关系的映射 - TerryLee‘s Tech Space - 博客园 Alex‘s space: MVP vs MVC ad-hoc网络_seribor 's space ad-hoc网络_seribor 's space space: 搜索引擎学习资源收集[转帖] Eric‘s Space: 破解Myspace成功之谜 David‘s Personal Space: 苏联的登月计划 [资料] Nwupspx.sys/清除nwupspx病毒 By MortaLove._MortaLove ‘s Space. Castle IOC容器快速入门 - TerryLee‘s Tech Space - 博客... 手机的软件工作原理 - 临时工 Temporary's Space - CSDNBlog 数据库设计指南[整理] - Aero‘s Tech Space - 博客园 Russia's new space launch center construction, another ambitious project? U.S.A.F. — It's Space For SBSS (Launch) Eric‘s Space: 从网站运营逆向思考网站平台的作用与建设 Castle IOC容器构建配置详解(一) - TerryLee‘s Tech Space... 增加CCS1.1的Blog日志访问者记录功能 - Aero‘s Tech Space - ... 红稻米粥 - lineng's space - 美丽人生 生活驿站 品质生活 我创造 -... 探究C/C 可变参数 - GUANZHONG 's Sharing Space - CSDN博客 淘宝网上商城的盈利模式思考 - greengnn‘s space | web design :: web develop :: web standard