在Oracle遞歸查詢中,我們經常用到的是Start with...Connect By子句來對Oracle遞歸查詢一般的情況下,是用於相關表維護樹形的結構應用。以下就是文章的相關內容的具體介紹,望你浏覽後會對你有所幫助。
創建示例表:
Sql代碼
- CREATE TABLE TBL_TEST
- (
- ID NUMBER,
- NAME VARCHAR2(100 BYTE),
- PID NUMBER DEFAULT 0
- );
插入測試數據:
Sql代碼
- INSERT INTO TBL_TEST(ID,NAME,PID) VALUES('1','10','0');
- INSERT INTO TBL_TEST(ID,NAME,PID) VALUES('2','11','1');
- INSERT INTO TBL_TEST(ID,NAME,PID) VALUES('3','20','0');
- INSERT INTO TBL_TEST(ID,NAME,PID) VALUES('4','12','1');
- INSERT INTO TBL_TEST(ID,NAME,PID) VALUES('5','121','2');
在Oracle遞歸查詢中我們要用到Sql代碼
從Root往樹末梢遞歸
- select * from TBL_TEST
- start with id=1
- connect by prior id = pid
Sql代碼
從末梢往樹ROOT遞歸
- select * from TBL_TEST
- start with id=5
- connect by prior pid = id