Oracle 使用遞迴的效能提示

來源:互聯網
上載者:User

當你用start with  connect by nocycle prior

進行遞迴尋找資料的時候

那麼下面兩段代碼的效能肯定是有明顯差別的 大家用的時候 請注意了 代碼可以不看下面 直接看我的總結

//查詢某個檔案夾檔案夾ID=12裡面的層次數以及 檔案的個數

A:為檔案之間的關聯關係 上下級關係

B:為檔案夾裡面的檔案

正解:

select count(0) cou,max(levels)+1 as  levels

select  C.a1,C.a2,C.levels...

from

(Select A.a1 ,A.a2,,,

level  levels//層次關係

from A

where A.a1=,,,

and A.a2=....

start with A.a1 = 12

connect by nocylce prior  A.ID=A.ParentID

) C left join  B

on C.檔案ID=B.檔案ID

and  C.檔案類型=檔案夾

錯解:

select count(0) cou,max(levels)+1 as  levels

select  C.a1,C.a2,C.levels...

from

(Select A.a1 ,A.a2,,,

level  levels//層次關係

from A

left join  B

on C.檔案ID=B.檔案ID

where C.檔案類型=檔案夾

and A.a1=,,,

and A.a2=....

start with A.a1 = 12

connect by nocylce prior  A.ID=A.ParentID

) C

上面代碼的區別在於

正確的做法是:

先遞迴迴圈出某個檔案夾下面的 所有的檔案夾以及檔案

在關聯檔案表 尋找檔案的內容

錯誤的做法是:

先找到某個檔案夾下面的 檔案夾和檔案

然後再 遞迴迴圈出 他下面的檔案夾裡面所有的檔案夾以及檔案

這樣就造成了關聯關聯後冗餘的資料 一起進行了 迴圈遞迴 本來就和檔案沒有關係 不應該吧檔案也放進來遞迴

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.