oracle 使用遞歸的性能提示測試對比
更新時間:2013年02月05日 09:24:49 作者:
先遞歸循環(huán)出某個文件夾下面的所有的文件夾以及文件在關(guān)聯(lián)文件表查找文件的內(nèi)容這是正確的做法,感興趣的朋友可以了解下,或許對你學(xué)習(xí)oracle遞歸有所幫助
當(dāng)你用start with connect by nocycle prior
進(jìn)行遞歸查找數(shù)據(jù)的時候那么下面兩段代碼的性能肯定是有明顯差別的大家用的時候 請注意了代碼可以不看下面 直接看我的總結(jié)
//查詢某個文件夾文件夾ID=12里面的層次數(shù)以及 文件的個數(shù)
A:為文件之間的關(guān)聯(lián)關(guān)系 上下級關(guān)系
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//層次關(guān)系
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//層次關(guān)系
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
上面代碼的區(qū)別在于
正確的做法是:
先遞歸循環(huán)出某個文件夾下面的所有的文件夾以及文件在關(guān)聯(lián)文件表查找文件的內(nèi)容
錯誤的做法是:
先找到某個文件夾下面的 文件夾和文件
然后再 遞歸循環(huán)出 他下面的文件夾里面所有的文件夾以及文件
這樣就造成了關(guān)聯(lián)關(guān)聯(lián)后冗余的數(shù)據(jù) 一起進(jìn)行了 循環(huán)遞歸 本來就和文件沒有關(guān)系 不應(yīng)該吧文件也放進(jìn)來遞歸
進(jìn)行遞歸查找數(shù)據(jù)的時候那么下面兩段代碼的性能肯定是有明顯差別的大家用的時候 請注意了代碼可以不看下面 直接看我的總結(jié)
//查詢某個文件夾文件夾ID=12里面的層次數(shù)以及 文件的個數(shù)
A:為文件之間的關(guān)聯(lián)關(guān)系 上下級關(guān)系
B:為文件夾里面的文件
正解:
復(fù)制代碼 代碼如下:
select count(0) cou,max(levels)+1 as levels
select C.a1,C.a2,C.levels...
from
(Select A.a1 ,A.a2,,,
level levels//層次關(guān)系
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.文件類型=文件夾
錯解:
復(fù)制代碼 代碼如下:
select count(0) cou,max(levels)+1 as levels
select C.a1,C.a2,C.levels...
from
(Select A.a1 ,A.a2,,,
level levels//層次關(guān)系
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
上面代碼的區(qū)別在于
正確的做法是:
先遞歸循環(huán)出某個文件夾下面的所有的文件夾以及文件在關(guān)聯(lián)文件表查找文件的內(nèi)容
錯誤的做法是:
先找到某個文件夾下面的 文件夾和文件
然后再 遞歸循環(huán)出 他下面的文件夾里面所有的文件夾以及文件
這樣就造成了關(guān)聯(lián)關(guān)聯(lián)后冗余的數(shù)據(jù) 一起進(jìn)行了 循環(huán)遞歸 本來就和文件沒有關(guān)系 不應(yīng)該吧文件也放進(jìn)來遞歸
相關(guān)文章
Oracle刪除數(shù)據(jù)報ORA 02292錯誤的巧妙解決方法
這篇文章主要介紹了Oracle刪除數(shù)據(jù)報ORA 02292錯誤的巧妙解決方法,需要的朋友可以參考下2017-07-07
Navicat設(shè)置Oracle數(shù)據(jù)庫主鍵自增的方法步驟
今天工作的時候,用到了oracle數(shù)據(jù)庫建表,發(fā)現(xiàn)navicat中對于oracle的支持沒有那個主鍵自增的按鈕,下面這篇文章主要給大家介紹了關(guān)于Navicat設(shè)置Oracle數(shù)據(jù)庫主鍵自增的方法步驟,需要的朋友可以參考下2023-03-03
oracle數(shù)據(jù)庫sql的優(yōu)化總結(jié)
自己對oracle sql的一些優(yōu)化總結(jié),特分享下,方便需要的朋友2013-08-08
Oracle 數(shù)據(jù)庫自動存儲管理-安裝配置
關(guān)于ASM的討論很多,但是到底什么是ASM?ASM是一個有效的抽象層,使你的Oracle數(shù)據(jù)庫可以與叫做diskgroups的抽象空間一起使用,而不是直接使用datafiles。2009-05-05

