站長資訊網
最全最豐富的資訊網站

一文解析ORACLE樹結構查詢

本篇文章給大家帶來了關于Oracle的相關知識,主要介紹了一文解析ORACLE樹結構查詢,文章圍繞主題展開詳細的內容戒殺,下面一起來看一下,希望對大家有幫助。

一文解析ORACLE樹結構查詢

推薦教程:《Oracle視頻教程》

我們在日常程序設計中,經常會遇到樹狀結構的表示,例如組織機構、行政區劃等等。這些在數據庫中往往通過一張表進行展示。這里我們以一張簡單的行政區劃表為例進行展示,在實際使用過程中,可以為其添加其他描述字段以及層級。

一文解析ORACLE樹結構查詢

表中通過ID和PID關聯,實現樹狀結構的存儲。建表以及數據語句如下:

-- Create table create table TREETEST (   id   NVARCHAR2(50),   pid  NVARCHAR2(50),   name NVARCHAR2(50) )
insert into TREETEST (ID, PID, NAME) values ('1', null, '山東省'); insert into TREETEST (ID, PID, NAME) values ('2', '1', '青島市'); insert into TREETEST (ID, PID, NAME) values ('3', '1', '煙臺市'); insert into TREETEST (ID, PID, NAME) values ('4', null, '河南省'); insert into TREETEST (ID, PID, NAME) values ('5', null, '河北省'); insert into TREETEST (ID, PID, NAME) values ('6', '2', '市南區'); insert into TREETEST (ID, PID, NAME) values ('7', '2', '市北區'); insert into TREETEST (ID, PID, NAME) values ('8', '2', '即墨市');

那對于樹狀結構如何查詢呢?Oracle提供遞歸查詢的方式進行查詢,基本語法如下:

SELECT [Column]…..   FEOM [Table]   WHERE Conditional1   START WITH Conditional2   CONNECT BY PRIOR Conditional3   ORDER BY [Column]

說明:

  • 條件1—過濾條件,對全部返回的記錄進行過濾。
  • 條件2—根節點的限定條件,固然也可以放寬權限得到多個根節點,也就是獲取多個樹
  • 條件3—鏈接條件,目的就是給出父子之間的關系是什么,根據這個關系進行遞歸查詢(在上述表中就是ID=PID)
  • 排序—對全部返回記錄進行排序

下面我們結合具體實例來看:

1、查詢山東省下面的所有子節點

SELECT *   FROM TREETEST t  START WITH t.PID=1 CONNECT BY PRIOR t.ID = t.PID

其中ID為1的為山東省節點,查詢結果如下:

一文解析ORACLE樹結構查詢

2、查詢青島市的下一級子節點(注意和上面區分,全部子節點和下一級子節點)

一文解析ORACLE樹結構查詢

3、如果需要獲取將山東省青島市等連接起來顯示,可以使用SYS_CONNECT_BY_PATH來實現

SELECT t.ID, SYS_CONNECT_BY_PATH(t.NAME, '') AS INDU_NAME   FROM TREETEST t  START WITH t.PID IS NULL CONNECT BY PRIOR t.ID = t.PID

查詢結果如下:

一文解析ORACLE樹結構查詢

4、同理,也可以從下往上進行查詢

SELECT *   FROM TREETEST t  START WITH t.ID=8 CONNECT BY t.ID = PRIOR t.PID

一文解析ORACLE樹結構查詢

推薦教程:《Oracle視頻教程》

前端(vue)入門到精通課程:立即學習

贊(0)
分享到: 更多 (0)
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
538精品在线观看| 久久久国产精品网站| 狠狠色伊人久久精品综合网| 国产精品无码一区二区三区在| 亚洲国产成人91精品| 亚洲AV成人精品网站在线播放| 亚洲an日韩专区在线| 精品久久亚洲一级α| 内射精品无码中文字幕| 国产精品视频分类一区| 中国精品videossex中国高清| 久久国产精品二区99| 久久er国产精品免费观看2| 国产在线无码精品电影网| 久久久久国产精品三级网| 国产精品色视频ⅹxxx| 亚洲人成电影网站国产精品| www国产精品内射老熟女| 97久久超碰国产精品旧版| 亚洲国产精品成人综合久久久| 99re5精品视频在线观看| 日韩精品真人荷官无码| 久久99热66这里只有精品一| 国产99视频精品免费视频76| 亚洲AV日韩AV永久无码色欲| 日韩免费视频一区二区| 国产精品一区二区不卡| 亚洲精品日韩中文字幕久久久| 久久99精品久久久久久动态图 | 精品少妇一区二区三区在线| 精品国产高清久久久久久小说| 亚洲AV综合永久无码精品天堂| 97久久久精品综合88久久| 国内精品久久国产| 亚洲最大天堂无码精品区| 久久国产精品久久精| 久久国产精品99久久久久久牛牛| 国产精品无码成人午夜电影| 国内精品人妻无码久久久影院 | 国产精品机视频大陆| 久久91精品国产91久|