色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

Oracle遞歸查詢簡單示例

瀏覽:205日期:2023-03-12 15:25:41
目錄
  • 1 數據準備
  • 2 start with connect by prior遞歸查詢
    • 2.1 查詢所有子節點
    • 2.2 查詢所有父節點
    • 2.3 查詢指定節點的,根節點
    • 2.4 查詢巴中市下行政組織遞歸路徑
  • 3 with遞歸查詢
    • 3.1 with遞歸子類
    • 3.2 遞歸父類
  • 補充:實例
    • 總結

      1 數據準備

      create table area_test(  id number(10) not null,  parent_id  number(10),  name       varchar2(255) not null);alter table area_test add (constraint district_pk primary key (id));insert into area_test (ID, PARENT_ID, NAME) values (1, null, "中國");insert into area_test (ID, PARENT_ID, NAME) values (11, 1, "河南省"); insert into area_test (ID, PARENT_ID, NAME) values (12, 1, "北京市");insert into area_test (ID, PARENT_ID, NAME) values (111, 11, "鄭州市");insert into area_test (ID, PARENT_ID, NAME) values (112, 11, "平頂山市");insert into area_test (ID, PARENT_ID, NAME) values (113, 11, "洛陽市");insert into area_test (ID, PARENT_ID, NAME) values (114, 11, "新鄉市");insert into area_test (ID, PARENT_ID, NAME) values (115, 11, "南陽市");insert into area_test (ID, PARENT_ID, NAME) values (121, 12, "朝陽區");insert into area_test (ID, PARENT_ID, NAME) values (122, 12, "昌平區");insert into area_test (ID, PARENT_ID, NAME) values (1111, 111, "二七區");insert into area_test (ID, PARENT_ID, NAME) values (1112, 111, "中原區");insert into area_test (ID, PARENT_ID, NAME) values (1113, 111, "新鄭市");insert into area_test (ID, PARENT_ID, NAME) values (1114, 111, "經開區");insert into area_test (ID, PARENT_ID, NAME) values (1115, 111, "金水區");insert into area_test (ID, PARENT_ID, NAME) values (1121, 112, "湛河區");insert into area_test (ID, PARENT_ID, NAME) values (1122, 112, "舞鋼市");insert into area_test (ID, PARENT_ID, NAME) values (1123, 112, "寶豐市");insert into area_test (ID, PARENT_ID, NAME) values (11221, 1122, "尚店鎮");

      2 start with connect by prior遞歸查詢

      2.1 查詢所有子節點

      select *from area_teststart with name ="鄭州市"connect by prior id=parent_id

      2.2 查詢所有父節點

      select t.*,levelfrom area_test tstart with name ="鄭州市"connect by prior t.parent_id=t.idorder by level asc;

      start with 子句:遍歷起始條件,如果要查父結點,這里可以用子結點的列,反之亦然。
      connect by 子句:連接條件。prior 跟父節點列parentid放在一起,就是往父結點方向遍歷;prior 跟子結點列subid放在一起,則往葉子結點方向遍歷。parent_id、id兩列誰放在“=”前都無所謂,關鍵是prior跟誰在一起。
      order by 子句:排序。

      2.3 查詢指定節點的,根節點

      select d.*,	   connect_by_root(d.id) rootid,	   connect_by_root(d.name) rootnamefrom area_test dwhere name="二七區"start with d.parent_id IS NULLconnect by prior d.id=d.parent_id

      2.4 查詢巴中市下行政組織遞歸路徑

      select id, parent_id, name, sys_connect_by_path(name, "->") namepath, levelfrom area_teststart with name = "平頂山市"connect by prior id = parent_id

      3 with遞歸查詢

      3.1 with遞歸子類

      with tmp(id, parent_id, name) as (	select id, parent_id, name    from area_test    where name = "平頂山市"    union all    select d.id, d.parent_id, d.name    from tmp, area_test d    where tmp.id = d.parent_id   )select * from tmp;

      3.2 遞歸父類

      with tmp(id, parent_id, name) as  (   select id, parent_id, name   from area_test   where name = "二七區"   union all   select d.id, d.parent_id, d.name   from tmp, area_test d   where tmp.parent_id = d.id   )select * from tmp;

      補充:實例

      我們稱表中的數據存在父子關系,通過列與列來關聯的,這樣的數據結構為樹結構。

      現在有一個menu表,字段有id,pid,title三個。

      查詢菜單id為10的所有子菜單。

      SELECT * FROM tb_menu m START WITH m.id=10 CONNECT BY m.pid=PRIOR m.id;

      將PRIOR關鍵字放在m.id前面,意思就是查詢pid是當前記錄id的記錄,如此順延找到所有子節點。

      查詢菜單id為40的所有父菜單。

      SELECT * FROM tb_menu m START WITH m.id=40 CONNECT BY PRIOR m.pid= m.id ORDER BY ID;

      總結

      到此這篇關于Oracle遞歸查詢的文章就介紹到這了,更多相關Oracle遞歸查詢內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

      標簽: Oracle
      主站蜘蛛池模板: 免费韩国一级毛片 | 亚洲天天在线 | 日韩毛片欧美一级a网站 | cao在线| 欧美成a人片在线观看久 | 亚洲va久久久噜噜噜久久狠狠 | 久久草在线观看 | 美女一级片视频 | 免费精品99久久国产综合精品 | 免费欧洲毛片a级视频无风险 | 久久成年人 | 综合久久99久久99播放 | 黄网在线观看免费 | 91亚洲精品一区二区在线观看 | 永久免费91桃色福利 | 久久精品国产99国产精品 | 国产成人欧美一区二区三区的 | 国产精品美女一区二区 | 台湾黄三级高清在线观看播放 | 国产成人综合日韩精品婷婷九月 | 成人精品视频一区二区三区 | 成人在线网站 | 超级碰碰碰视频视频在线视频 | 久久成人免费观看草草影院 | 99热成人精品热久久66 | www.av在线视频| 欧美成人鲁丝片在线观看 | 亚洲www色| 国产亚洲综合精品一区二区三区 | 国产精品一区在线免费观看 | 国产精品久久久久免费视频 | 91精选视频在线观看 | 特级毛片aaa免费版 特级毛片a级毛免费播放 | 女人张开腿让男人桶免费网站 | 午夜桃色剧场 | 国产午夜精品久久久久免费视 | 欧美一级视频高清片 | 97影院理伦在线观看 | 国产亚洲一区二区三区 | 欧美成人aa | 成人影院欧美大片免费看 |