国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > Oracle > 正文

oracle 使用遞歸的性能提示測試對比

2020-07-26 14:28:02
字體:
來源:轉載
供稿:網友
當你用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

上面代碼的區別在于
正確的做法是
先遞歸循環出某個文件夾下面的所有的文件夾以及文件在關聯文件表查找文件的內容
錯誤的做法是
先找到某個文件夾下面的 文件夾和文件
然后再 遞歸循環出 他下面的文件夾里面所有的文件夾以及文件
這樣就造成了關聯關聯后冗余的數據 一起進行了 循環遞歸 本來就和文件沒有關系 不應該吧文件也放進來遞歸
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 长宁区| 桐柏县| 仁化县| 西乌珠穆沁旗| 鄢陵县| 克什克腾旗| 赤壁市| 巴林左旗| 永康市| 新营市| 千阳县| 岚皋县| 合川市| 区。| 英超| 呼伦贝尔市| 黄龙县| 楚雄市| 昭通市| 吴桥县| 郯城县| 嘉鱼县| 车致| 琼中| 荆州市| 白城市| 定南县| 东乡族自治县| 丰县| 阿合奇县| 宝丰县| 新龙县| 台南县| 车致| 张掖市| 金坛市| 大关县| 平果县| 彭泽县| 佛冈县| 马边|