oracle 的 start with connect by prior 學習

來源:互聯網
上載者:User

標籤:_id   insert   ack   val   nbsp   http   snap   用法   .com   

文法:

SELECT ... FROM    + 表名 
START WITH         +條件1
CONNECT BY PRIOR   + 條件2
WHERE             + 條件3

 

說明:

這個方法是用來查詢樹狀結構的資料的。舉個例子,我們有一個這樣的結構

 

 

然後建一個這樣的表,插入資料。

CREATE TABLE TEST(

        ID NUMBER(2) PRIMARYKEY,

        PARENT_ID NUMBER(2)

);

 

INSERT INTO TEST (ID, PARENT_ID) VALUES (1, 0);

INSERT INTO TEST (ID, PARENT_ID) VALUES (2, 1);

INSERT INTO TEST (ID, PARENT_ID) VALUES (3, 1);

INSERT INTO TEST (ID, PARENT_ID) VALUES (4, 2);

INSERT INTO TEST (ID, PARENT_ID) VALUES (5, 2);

INSERT INTO TEST (ID, PARENT_ID) VALUES (6, 3);

INSERT INTO TEST (ID, PARENT_ID) VALUES (7, 3);

 

現在,我們可以開始查詢了。

比如,我們要查詢ID為3的子節點有哪些:

 

SELECT * FROM TEST START WITH ID = 3CONNECT BY   PARENT_ID = PRIOR ID;

結果:

 


 

查詢1的子節點:

 


 

查詢3的父節點有哪些:

SELECT * FROM TEST START WITH ID = 3CONNECT BY PRIOR  PARENT_ID =  ID

結果:

 


查詢7的父節點有哪些:

 

基本用法就是這樣了

 

 

 

 

oracle 的 start with connect by prior 學習

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.