(Les18 Hierarchical Retrieving)[20180105]

来源:https://www.cnblogs.com/also-brook/archive/2018/01/05/8207265.html
-Advertisement-
Play Games

學習目標 -理解分層查詢概念 -創建樹形組織報告 -格式化分層數據 -樹形組織排除分支 分層查詢 語法 SELECT [LEVEL],<column>,exper ... FROM <table_name> [WHERE condition(s)] START WITH condition(s) C ...


學習目標     -理解分層查詢概念     -創建樹形組織報告     -格式化分層數據     -樹形組織排除分支       分層查詢         語法
 SELECT [LEVEL],<column>,exper ...
        FROM <table_name>
        [WHERE condition(s)]
        START WITH condition(s)
        CONNECT BY PRIOR condition(s);

 

LEVEL關鍵字返回層次查詢中的層級數 START WITH 指定層級開始的第一級 CONNECT BY PRIOR 指定父行和子行之間的關係列,此子句是層次查詢必需的           知識點 Oracle中start with...connect by prior子句用法  connect by 是結構化查詢中用到的,其基本語法是:  select ... from tablename start with 條件1  connect by 條件2  where 條件3; 例: select * from table start with org_id = 'HBHqfWGWPy' connect by prior org_id = parent_id; 簡單說來是將一個樹狀結構存儲在一張表裡,比如一個表中存在兩個欄位:  org_id,parent_id那麼通過表示每一條記錄的parent是誰,就可以形成一個樹狀結構。  用上述語法的查詢可以取得這棵樹的所有記錄。  其中: 條件1 是根結點的限定語句,當然可以放寬限定條件,以取得多個根結點,實際就是多棵樹。  條件2 是連接條件,其中用PRIOR表示上一條記錄,比如 CONNECT BY PRIOR org_id = parent_id就是說上一條記錄的org_id 是本條記錄的parent_id,即本記錄的父親是上一條記錄。  條件3 是過濾條件,用於對返回的所有記錄進行過濾。 簡單介紹如下: 早掃描樹結構表時,需要依此訪問樹結構的每個節點,一個節點只能訪問一次,其訪問的步驟如下: 第一步:從根節點開始; 第二步:訪問該節點; 第三步:判斷該節點有無未被訪問的子節點,若有,則轉向它最左側的未被訪問的子節,並執行第二步,否則執行第四步; 第四步:若該節點為根節點,則訪問完畢,否則執行第五步; 第五步:返回到該節點的父節點,並執行第三步驟。   總之:掃描整個樹結構的過程也即是中序遍歷樹的過程。   1. 樹結構的描述 樹結構的數據存放在表中,數據之間的層次關係即父子關係,通過表中的列與列間的關係來描述,如EMP表中的EMPNO和MGR。EMPNO表示該雇員的編號,MGR表示領導該雇員的人的編號,即子節點的MGR值等於父節點的EMPNO值。在表的每一行中都有一個表示父節點的MGR(除根節點外),通過每個節點的父節點,就可以確定整個樹結構。 在SELECT命令中使用CONNECT BY 和藹START WITH 子句可以查詢表中的樹型結構關係。其命令格式如下: SELECT 。。。 CONNECT BY {PRIOR 列名1=列名2|列名1=PRIOR 裂名2} [START WITH]; 其中:CONNECT BY子句說明每行數據將是按層次順序檢索,並規定將表中的數據連入樹型結構的關係中。PRIORY運算符必須放置在連接關係的兩列中某一個的前面。對於節點間的父子關係,PRIOR運算符在一側表示父節點,在另一側表示子節點,從而確定查找樹結構是的順序是自頂向下還是自底向上。在連接關係中,除了可以使用列名外,還允許使用列表達式。START WITH 子句為可選項,用來標識哪個節點作為查找樹型結構的根節點。若該子句被省略,則表示所有滿足查詢條件的行作為根節點。 START WITH: 不但可以指定一個根節點,還可以指定多個根節點。 2. 關於PRIOR 運算符PRIOR被放置於等號前後的位置,決定著查詢時的檢索順序。 PRIOR被置於CONNECT BY子句中等號的前面時,則強制從根節點到葉節點的順序檢索,即由父節點向子節點方向通過樹結構,我們稱之為自頂向下的方式。如: CONNECT BY PRIOR EMPNO=MGR PIROR運算符被置於CONNECT BY 子句中等號的後面時,則強制從葉節點到根節點的順序檢索,即由子節點向父節點方向通過樹結構,我們稱之為自底向上的方式。例如: CONNECT BY EMPNO=PRIOR MGR 在這種方式中也應指定一個開始的節點。 3. 定義查找起始節點 在自頂向下查詢樹結構時,不但可以從根節點開始,還可以定義任何節點為起始節點,以此開始向下查找。這樣查找的結果就是以該節點為開始的結構樹的一枝。 4.使用LEVEL 在具有樹結構的表中,每一行數據都是樹結構中的一個節點,由於節點所處的層次位置不同,所以每行記錄都可以有一個層號。層號根據節點與根節點的距離確定。不論從哪個節點開始,該起始根節點的層號始終為1,根節點的子節點為2, 依此類推。圖1.2就表示了樹結構的層次。 5.節點和分支的裁剪 在對樹結構進行查詢時,可以去掉表中的某些行,也可以剪掉樹中的一個分支,使用WHERE子句來限定樹型結構中的單個節點,以去掉樹中的單個節點,但它卻不影響其後代節點(自頂向下檢索時)或前輩節點(自底向頂檢索時)。 6.排序顯示 象在其它查詢中一樣,在樹結構查詢中也可以使用ORDER BY 子句,改變查詢結果的顯示順序,而不必按照遍歷樹結構的順序。     例子:
 HR@cqoraxt0>select last_name,employee_id,manager_id,level from employees
start with employee_id =100
connect by prior employee_id=manager_id ;
LAST_NAME            EMPLOYEE_ID MANAGER_ID      LEVEL
-------------------- ----------- ---------- ----------
Dereck                       100          1          1
Gary                         200        100          2
Gaga                         203        200          3
Wendy                        204        200          3
Xi                           205        200          3
Tinan                        206        200          3
Ling                         207        200          3
Klec                         300        100          2
Owen                         301        300          3
Yi                           302        300          3
        
註意:connect by prior鏈接順序
HR
@cqoraxt0> select last_name,employee_id,manager_id,level from employees start with employee_id =302 connect by prior manager_id=employee_id order siblings by last_name; LAST_NAME EMPLOYEE_ID MANAGER_ID LEVEL -------------------- ----------- ---------- ---------- Yi 302 300 1 Klec 300 100 2 Dereck 100 1 3
      格式化層次查詢         實現目標,採用層次查詢自動縮進           
HR@cqoraxt0>col last_name format a20
select lpad(last_name,length(last_name)+level,' ') last_name,employee_id,manager_id from employees
start with employee_id =100
connect by prior employee_id=manager_id;
 
LAST_NAME            EMPLOYEE_ID MANAGER_ID
-------------------- ----------- ----------
Dereck                      100          1
  Gary                       200        100
   Gaga                      203        200
   Wendy                     204        200
   Xi                        205        200
   Tinan                     206        200
   Ling                      207        200
  Klec                       300        100
   Owen                      301        300
   Yi                        302        300
 
HR@cqoraxt0>select lpad(last_name,length(last_name)+level,'-') last_name,employee_id,manager_id from employees
start with employee_id =100
connect by prior employee_id=manager_id;
 
LAST_NAME            EMPLOYEE_ID MANAGER_ID
-------------------- ----------- ----------
-Dereck                      100          1
--Gary                       200        100
---Gaga                      203        200
---Wendy                     204        200
---Xi                        205        200
---Tinan                     206        200
---Ling                      207        200
--Klec                       300        100
---Owen                      301        300
---Yi                        302        300
10 rows selected.
    排除分支             方式一:                     WHERE condition --排除指定分支單個節點                      START WITH                       CONNECT BY PRIOR             方式二:                     START WITH                     CONNECT BY PRIOR                     AND condition --排除分支             註意:方式一隻會排除單個節點,它下麵的從屬分支不會去掉。                  例子一             
HR@cqoraxt0>
select last_name,employee_id,manager_id,level from employees
where employee_id !=300
start with employee_id =100
connect by prior employee_id=manager_id
order siblings by last_name;
 
LAST_NAME            EMPLOYEE_ID MANAGER_ID      LEVEL
-------------------- ----------- ---------- ----------
Dereck                       100          1          1
Gary                         200        100          2
Gaga                         203        200          3
Ling                         207        200          3
Tinan                        206        200          3
Wendy                        204        200          3
Xi                           205        200          3
Owen                         301        300          3
Yi                           302        300          3
9 rows selected.
        例子二            
   HR@cqoraxt0>select last_name,employee_id,manager_id,level from employees
            start with employee_id =100
            connect by prior employee_id=manager_id
            and employee_id !=300
            order siblings by last_name;
 
LAST_NAME            EMPLOYEE_ID MANAGER_ID      LEVEL
-------------------- ----------- ---------- ----------
Dereck                       100          1          1
Gary                         200        100          2
Gaga                         203        200          3
Ling                         207        200          3
Tinan                        206        200          3
Wendy                        204        200          3
Xi                           205        200          3
 
7 rows selected.
 
學習總結:         1.層次查詢概念和使用方式         2.層次查詢start with、connect by prior子句和level偽列含義         3.通過level偽列對層次查詢數據進行格式化         4.排除層次查詢單個節點和分支



 
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、安裝vmware和創建虛擬機2、載入centos6.5的鏡像3、linux的介紹linux是一個操作系統(免費開源),來源unix linux是一個典型的樹形文件系統,一切都是基於文件。"/"稱之linux的根目錄即頂級目錄linux的每一個軟體都有缺點的用途,最小化安裝linux中僅有一個超級 ...
  • 一個用c語言寫的程式把他編譯成電腦可執行的文件,一般有4個步驟 1,預處理:這個步驟,主要是包含頭文件,展開巨集定義 gcc -E helloworld.c -o helloworld.i 2,生成彙編代碼 gcc -S helloworld.i -o helloworld.s 3,編譯彙編 gcc ...
  • Ubuntu中安裝mysql5.7時沒有設置密碼,使用mysql -u root -p 不能連接mysql服務 在網上查有兩種方式: 1. 第一次安裝,mysql5.7設置了個預設密碼在某個目錄下存放,使用預設密碼登錄後,會提示修改密碼。這個方法暫時沒有嘗試 2.修改mysql的配置文件sudo v ...
  • 學習目標 -正則元字元串 -SQL語句中使用正則搜索 -SQL語句中使用正則匹配 -SQL語句中使用正則替代字元串 正則表達式 Oracle資料庫10g引入對正則表達式的支持。 實現了符合UNIX可移植操作系統(POSIX)標準,由電氣和電子工程師協會(IEEE)控制,ASCII數據匹配的語義和語法 ...
  • 轉載songdeyouxiang 1、資料庫命名規範採用26個英文字母(區分大小寫)和0-9的自然數(經常不需要)加上下劃線'_'組成;命名簡潔明確(長度不能超過30個字元);例如:user, stat, log, 也可以wifi_user, wifi_stat, wifi_log給資料庫加個首碼; ...
  • 作者:NiceCui 本文謝絕轉載,如需轉載需徵得作者本人同意,謝謝。 本文鏈接:http://www.cnblogs.com/NiceCui/p/8213723.html 郵箱:[email protected] 日期:2017 12 20 mysql安裝、配置 1. yum 下載mysql 僅限 ...
  • 當一張的數據達到幾百萬時,你查詢一次所花的時間會變多,如果有聯合查詢的話,我想有可能會卡在那兒了,那麼分表的目的就在於此,減小資料庫的負擔,縮短查詢時間。 ...
  • 最近項目上裝的mysql服務,分配的磁碟空間太小了,導致binlog兩天時間就能打滿,這裡記錄下處理方式 mysql的binlog日誌是一個很重要的日誌,以事件形式記錄了所有的DDL和DML(除了數據查詢語句)語句,還包含執行的消耗的時間,在數據丟失的緊急情況下,我們可以利用binlog日誌功能進行 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...