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.