<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-314  評論-209  文章-0  trackbacks-0

    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 
    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 是標示父子關系的對應!

    如下例子:

    view plaincopy to clipboardprint?
    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 ; 
    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、帶層次關系

    view plaincopy to clipboardprint?
    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))  
    --------------------------------------------------------------------------------  
    總公司,浙江分公司,杭州分公司 
    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、行列轉換


    如把一個表的所有列連成一行,用逗號分隔:

    view plaincopy to clipboardprint?
    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 

    posted on 2011-08-05 11:03 xzc 閱讀(1404) 評論(3)  編輯  收藏 所屬分類: Oracle

    評論:
    # re: SYS_CONNECT_BY_PATH函數用法 ORACLE 2011-08-05 11:06 | xzc
    SQL> select substr(max(sys_connect_by_path(attr_value, ',')), 2)
    2 from (select attr_value, rownum rn
    3 from attribute_value
    4 where attr_id in
    5 (select attr_id from attribute where attr_code = 'lan_id'))
    6 start with rn = 1
    7 connect by rn = rownum;

    SUBSTR(MAX(SYS_CONNECT_BY_PATH
    --------------------------------------------------------------------------------
    470,471,472,473,474,475,476,477,478,479,482,483  回復  更多評論
      
    # re: SYS_CONNECT_BY_PATH函數用法 ORACLE 2011-08-05 11:09 | xzc
    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;

    select substr(max(sys_connect_by_path(attr_value, ',')), 2)
    from (select attr_value, rownum rn
    from attribute_value
    where attr_id in
    (select attr_id from attribute where attr_code = 'lan_id'))
    start with rn = 1
    connect by rn = rownum;  回復  更多評論
      
    # re: SYS_CONNECT_BY_PATH函數用法 ORACLE 2012-07-12 21:22 | xzc
    SQL> select wm_concat(lan_id) from rr_lan;

    WM_CONCAT(LAN_ID)
    --------------------------------------------------------------------------------
    471,470,472,473,474,475,476,477,478,479,482,483  回復  更多評論
      
    主站蜘蛛池模板: 99久久免费中文字幕精品| 一级毛片不卡免费看老司机| 一级毛片全部免费播放| 亚洲色婷婷一区二区三区| 成年免费a级毛片| 亚洲精品亚洲人成在线观看下载| 羞羞视频免费网站含羞草| 免费人成在线观看视频播放| 日韩在线观看视频免费| 国产亚洲美女精品久久久| 成人精品视频99在线观看免费| 伊人久久大香线蕉亚洲五月天| 一个人免费观看视频在线中文| 亚洲综合另类小说色区色噜噜| 国产精品午夜免费观看网站 | 久久er国产精品免费观看2| 亚洲香蕉成人AV网站在线观看| 免费国产成人18在线观看| 亚洲第一成年人网站| 黄色成人网站免费无码av| 亚洲精品亚洲人成在线| 免费人成网站在线播放| A国产一区二区免费入口| 亚洲av无码无在线观看红杏| 3344永久在线观看视频免费首页| 天天爽亚洲中文字幕| 免费h成人黄漫画嘿咻破解版| 亚洲国产免费综合| 亚洲黄色片免费看| 成人五级毛片免费播放| 一级毛片免费播放试看60分钟| 亚洲精品无码久久久久去q| 精品香蕉在线观看免费| 鲁啊鲁在线视频免费播放| 亚洲精品国产美女久久久| 久久久久久久91精品免费观看| 高h视频在线免费观看| 亚洲五月激情综合图片区| 日韩中文无码有码免费视频| 免费无码黄网站在线看| 亚洲国产激情在线一区|