日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

oracle10递归 nocycle,oracle 使用递归的性能提示测试对比

發布時間:2023/12/19 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 oracle10递归 nocycle,oracle 使用递归的性能提示测试对比 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

當你用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

上面代碼的區別在于

正確的做法是:

先遞歸循環出某個文件夾下面的所有的文件夾以及文件在關聯文件表查找文件的內容

錯誤的做法是:

先找到某個文件夾下面的 文件夾和文件

然后再 遞歸循環出 他下面的文件夾里面所有的文件夾以及文件

這樣就造成了關聯關聯后冗余的數據 一起進行了 循環遞歸 本來就和文件沒有關系 不應該吧文件也放進來遞歸

免責聲明:本站所有文章和圖片均來自用戶分享和網絡收集,文章和圖片版權歸原作者及原出處所有,僅供學習與參考,請勿用于商業用途,如果損害了您的權利,請聯系網站客服處理。

總結

以上是生活随笔為你收集整理的oracle10递归 nocycle,oracle 使用递归的性能提示测试对比的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。