oracle 層次化查詢(行政區(qū)劃三級級聯(lián))
更新時間:2009年07月25日 10:52:21 作者:
現(xiàn)在將上面的行政區(qū)劃按代碼分為三個級別:?。ê笏奈粸?)/市(后兩位為0)/縣,同時分別標(biāo)出他們的級別,這樣的話,便于后期根據(jù)不同的級別查詢。
前提:
數(shù)據(jù)庫表DM_xzqh樣例(部分):
DM MC
230000 黑龍江省
230100 哈爾濱市
230101 市轄區(qū)
230102 道里區(qū)
232700 大興安嶺
230103 南崗區(qū)
230104 道外區(qū)
230108 平房區(qū)
230109 松北區(qū)
230110 香坊區(qū)
230111 呼蘭區(qū)
230112 阿城區(qū)
230123 依蘭縣
238000 農(nóng)墾分局
230124 方正縣
230125 賓縣
230126 巴彥縣
230127 木蘭縣
230128 通河縣
230129 延壽縣
230182 雙城市
230183 尚志市
現(xiàn)在將上面的行政區(qū)劃按代碼分為三個級別:?。ê笏奈粸?)/市(后兩位為0)/縣,同時分別標(biāo)出他們的級別,這樣的話,便于后期根據(jù)不同的級別查詢。
首先,根據(jù)上面表拓展出新的一行sjbm,該行用于表示該行政區(qū)劃所屬的上級行政區(qū)劃。具體代碼如下:
select t.dm,t.mc,case
when substr(t.dm,3)='0000' then 1
when substr(t.dm,5)='00' then to_number(substr(t.dm,1,2)||'0000')
when substr(t.dm,5)!='00' then to_number(substr(t.dm,1,4)||'00')
else 0
end sjbm from dm_xzqh t
結(jié)果如下:
序號 DM MC SJBM
1 230000 黑龍江省 1
2 230100 哈爾濱市 230000
3 230101 市轄區(qū) 230100
4 230102 道里區(qū) 230100
5 232700 大興安嶺 230000
6 230103 南崗區(qū) 230100
7 230104 道外區(qū) 230100
8 230108 平房區(qū) 230100
9 230109 松北區(qū) 230100
10 230110 香坊區(qū) 230100
11 230111 呼蘭區(qū) 230100
12 230112 阿城區(qū) 230100
13 230123 依蘭縣 230100
14 238000 農(nóng)墾分局 230000
15 230124 方正縣 230100
16 230125 賓縣 230100
17 230126 巴彥縣 230100
18 230127 木蘭縣 230100
19 230128 通河縣 230100
20 230129 延壽縣 230100
21 230182 雙城市 230100
22 230183 尚志市 230100
然后,就可以利用oracle的層次關(guān)系將該查詢出的數(shù)據(jù)分級了,具體代碼如下:
select level,dm,mc,sjbm from
(select t.dm,t.mc,case
when substr(t.dm,3)='0000' then 1
when substr(t.dm,5)='00' then to_number(substr(t.dm,1,2)||'0000')
when substr(t.dm,5)!='00' then to_number(substr(t.dm,1,4)||'00') end sjbm from dm_xzqh t)
[where level=2 ]--該條件語句用于查詢具體的每一個級別的行政區(qū)劃
start with sjbm=1
connect by prior dm=sjbm
[order by level];
結(jié)果如下:
序號 level DM MC SJBM
1 1 230000 黑龍江省 1 //省 ,level->1
2 2 230100 哈爾濱市 230000//市,level->2
3 3 230101 市轄區(qū) 230100//縣,level->3
4 3 230102 道里區(qū) 230100
5 3 230103 南崗區(qū) 230100
6 3 230104 道外區(qū) 230100
7 3 230108 平房區(qū) 230100
8 3 230109 松北區(qū) 230100
9 3 230110 香坊區(qū) 230100
10 3 230111 呼蘭區(qū) 230100
11 3 230112 阿城區(qū) 230100
12 3 230123 依蘭縣 230100
13 3 230124 方正縣 230100
14 3 230125 賓縣 230100
15 3 230126 巴彥縣 230100
16 3 230127 木蘭縣 230100
17 3 230128 通河縣 230100
18 3 230129 延壽縣 230100
19 3 230182 雙城市 230100
20 3 230183 尚志市 230100
21 3 230184 五常市 230100
22 2 232700 大興安嶺地區(qū) 230000
數(shù)據(jù)庫表DM_xzqh樣例(部分):
復(fù)制代碼 代碼如下:
DM MC
230000 黑龍江省
230100 哈爾濱市
230101 市轄區(qū)
230102 道里區(qū)
232700 大興安嶺
230103 南崗區(qū)
230104 道外區(qū)
230108 平房區(qū)
230109 松北區(qū)
230110 香坊區(qū)
230111 呼蘭區(qū)
230112 阿城區(qū)
230123 依蘭縣
238000 農(nóng)墾分局
230124 方正縣
230125 賓縣
230126 巴彥縣
230127 木蘭縣
230128 通河縣
230129 延壽縣
230182 雙城市
230183 尚志市
現(xiàn)在將上面的行政區(qū)劃按代碼分為三個級別:?。ê笏奈粸?)/市(后兩位為0)/縣,同時分別標(biāo)出他們的級別,這樣的話,便于后期根據(jù)不同的級別查詢。
首先,根據(jù)上面表拓展出新的一行sjbm,該行用于表示該行政區(qū)劃所屬的上級行政區(qū)劃。具體代碼如下:
復(fù)制代碼 代碼如下:
select t.dm,t.mc,case
when substr(t.dm,3)='0000' then 1
when substr(t.dm,5)='00' then to_number(substr(t.dm,1,2)||'0000')
when substr(t.dm,5)!='00' then to_number(substr(t.dm,1,4)||'00')
else 0
end sjbm from dm_xzqh t
結(jié)果如下:
序號 DM MC SJBM
1 230000 黑龍江省 1
2 230100 哈爾濱市 230000
3 230101 市轄區(qū) 230100
4 230102 道里區(qū) 230100
5 232700 大興安嶺 230000
6 230103 南崗區(qū) 230100
7 230104 道外區(qū) 230100
8 230108 平房區(qū) 230100
9 230109 松北區(qū) 230100
10 230110 香坊區(qū) 230100
11 230111 呼蘭區(qū) 230100
12 230112 阿城區(qū) 230100
13 230123 依蘭縣 230100
14 238000 農(nóng)墾分局 230000
15 230124 方正縣 230100
16 230125 賓縣 230100
17 230126 巴彥縣 230100
18 230127 木蘭縣 230100
19 230128 通河縣 230100
20 230129 延壽縣 230100
21 230182 雙城市 230100
22 230183 尚志市 230100
然后,就可以利用oracle的層次關(guān)系將該查詢出的數(shù)據(jù)分級了,具體代碼如下:
復(fù)制代碼 代碼如下:
select level,dm,mc,sjbm from
(select t.dm,t.mc,case
when substr(t.dm,3)='0000' then 1
when substr(t.dm,5)='00' then to_number(substr(t.dm,1,2)||'0000')
when substr(t.dm,5)!='00' then to_number(substr(t.dm,1,4)||'00') end sjbm from dm_xzqh t)
[where level=2 ]--該條件語句用于查詢具體的每一個級別的行政區(qū)劃
start with sjbm=1
connect by prior dm=sjbm
[order by level];
結(jié)果如下:
序號 level DM MC SJBM
1 1 230000 黑龍江省 1 //省 ,level->1
2 2 230100 哈爾濱市 230000//市,level->2
3 3 230101 市轄區(qū) 230100//縣,level->3
4 3 230102 道里區(qū) 230100
5 3 230103 南崗區(qū) 230100
6 3 230104 道外區(qū) 230100
7 3 230108 平房區(qū) 230100
8 3 230109 松北區(qū) 230100
9 3 230110 香坊區(qū) 230100
10 3 230111 呼蘭區(qū) 230100
11 3 230112 阿城區(qū) 230100
12 3 230123 依蘭縣 230100
13 3 230124 方正縣 230100
14 3 230125 賓縣 230100
15 3 230126 巴彥縣 230100
16 3 230127 木蘭縣 230100
17 3 230128 通河縣 230100
18 3 230129 延壽縣 230100
19 3 230182 雙城市 230100
20 3 230183 尚志市 230100
21 3 230184 五常市 230100
22 2 232700 大興安嶺地區(qū) 230000
相關(guān)文章
如何利用Oracle命令解決函數(shù)運(yùn)行錯誤
這篇文章主要給大家介紹了關(guān)于如何利用Oracle命令解決函數(shù)運(yùn)行錯誤的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者使用Oracle具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03Oracle統(tǒng)計(jì)信息的導(dǎo)出導(dǎo)入測試示例詳解
這篇文章主要給大家介紹了關(guān)于Oracle統(tǒng)計(jì)信息的導(dǎo)出導(dǎo)入測試的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-12-12oracle獲取上一旬的開始時間和結(jié)束時間的實(shí)現(xiàn)函數(shù)
本文為大家介紹下oracle如何獲取上一旬的開始時間和結(jié)束時間,實(shí)現(xiàn)函數(shù)如下,感興趣的朋友可以參考下2013-09-09oracle實(shí)現(xiàn)根據(jù)字段分組排序,取其第一條數(shù)據(jù)
這篇文章主要介紹了oracle實(shí)現(xiàn)根據(jù)字段分組排序,取其第一條數(shù)據(jù)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-02-02