oracle 樹形 sql查詢例子

2021-06-06 10:01:13 字數 1314 閱讀 3687

通過此sql語句 

select  * from tree
檢視原始資料如下:

我們要想得到如下的乙個樹形查詢結果如下圖所示(包含 root, level, is_leaf,  path 四個字段):

可執行如下sql語句:

select connect_by_root(child_col) root, level , decode(connect_by_isleaf,0,'no',1,'yes') is_leaf, sys_connect_by_path(child_col,'/') path

from tree

start with parent_col is null connect by prior child_col=parent_col;

樹形查詢的重點在於  start with ...  connect by prior .... 語句
以及 connect_by_root ,connect_by_isleaf,sys_connect_by_path這三個函式, decode是一般常用的函式。
其他參考:

動態查詢語句例子:

declare

n_rows number;

v_sql_stmt varchar2(50);

v_table_name varchar2(20);

v_name varchar2(20);

begin

v_table_name := 'tree';

v_sql_stmt := 'select count(*) from ' || v_table_name || ' where parent_col = :1';

v_name := 'asia';

dbms_output.put_line(v_sql_stmt);

execute immediate v_sql_stmt into n_rows using v_name;

dbms_output.put_line('the number of rows of' || v_table_name || 'is ' || n_rows);

end;

Oracle樹形查詢

基本語法 select.from tabename start with cond1 connect by prior cond2 where cond2 注 cond1是根節點的限定語句 cond2是連線條件,其中prior表示上一條記錄,指該記錄的父親是上一條記錄 cond3是過濾條件 構造環境...

oracle 樹形查詢

1.1 簡單的樹形查詢 select empno as 員工編碼,ename as 姓名,mgr as 主管,prior ename as 主管姓名 1.2 根節點,分支節點,葉節點 level 返回所在的等級 connect by isleaf 如果當前節點下沒有其他節點返回1,其他返回0。sel...

Oracle 樹形自關聯表查詢SQL

平時會經常用到自關聯的樹形結構表來儲存樹形結構的資料,資料之間的層次聯絡代表著樹形結構中的父子關係,並通常用表中兩個列間的聯絡來描述,如下表中id 和 parent id,id為家族成員編號,parent id為父母編號,從而可以形成乙個樹形結構的家族關係。一 基本用法 基本語句 select fr...