溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

Oracle遞歸查詢(xún)的幾種方法

發(fā)布時(shí)間:2020-07-19 17:12:02 來(lái)源:網(wǎng)絡(luò) 閱讀:367 作者:戀上程序員 欄目:關(guān)系型數(shù)據(jù)庫(kù)

oracle的start with connect by prior是根據(jù)條件遞歸查詢(xún)"樹(shù)",分為四種使用情況: 

第一種:start with 子節(jié)點(diǎn)ID='...' connect by prior 子節(jié)點(diǎn)ID = 父節(jié)點(diǎn)ID
1
select * from mdm_organization o start with o.org_code='10000008' connect by prior o.org_code=o.org_parent_code
 按照條件org_code='10000008',對(duì)'10000008'(包括自己)及其子節(jié)點(diǎn)進(jìn)行遞歸查詢(xún),結(jié)果如下

查詢(xún)結(jié)果自己所有的后代節(jié)點(diǎn)(包括自己)。

第二種:start with 子節(jié)點(diǎn)ID='...' connect by 子節(jié)點(diǎn)ID = prior 父節(jié)點(diǎn)ID
1
select * from mdm_organization o start with o.org_code='10000008' connect by o.org_code=prior o.org_parent_code
 按照條件org_code='10000008',對(duì)'10000008'(包括自己)及其父節(jié)點(diǎn)進(jìn)行遞歸查詢(xún),結(jié)果如下

 查詢(xún)結(jié)果自己所有的前代節(jié)點(diǎn)(包括自己)。

第三種:start with 父節(jié)點(diǎn)ID='...' connect by prior 子節(jié)點(diǎn)ID = 父節(jié)點(diǎn)ID
1
select * from mdm_organization o start with o.org_parent_code='10000008' connect by prior o.org_code=o.org_parent_code
 按照條件org_parent_code='10000008',對(duì)'10000008'(不包括自己)子節(jié)點(diǎn)進(jìn)行遞歸查詢(xún),結(jié)果如下

 查詢(xún)結(jié)果自己所有的后代節(jié)點(diǎn)(不包括自己)。

第四種:start with 父節(jié)點(diǎn)ID='...' connect by 子節(jié)點(diǎn)ID = prior 父節(jié)點(diǎn)ID
1
select * from mdm_organization o start with o.org_parent_code='10000008' connect by o.org_code = prior o.org_parent_code
按照條件org_parent_code='10000008',對(duì)'10000008'(包括自己)的第一代孩子們及其父節(jié)點(diǎn)進(jìn)行遞歸查詢(xún),結(jié)果如下

 查詢(xún)結(jié)果自己的第一代后節(jié)點(diǎn)和所有的前代節(jié)點(diǎn)(包括自己)。

 如果有where 條件,如下

 select * from mdm_organization o where 條件 start with o.org_parent_code='10000008' connect by o.org_code = prior o.org_parent_code

 執(zhí)行順序?yàn)橄葓?zhí)行start with connect by prior,然后再按照where條件進(jìn)行過(guò)濾。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI