Oracle 中Connect By 子句對在關系表上表現層次關系提供了方便
使用Connect by 子句需要在表中定義兩個字段
例如我們作一張資產負債表
數據來源
資 產 期末余額 負債及所有者權益 期末余額
流動資產
現金
存放中央銀行款項
存放同業款項
短期貸款
其他流動資產
長期資產
中長期貸款
減
固定資產淨值
其他長期資產
無形
其中
資產總計
Create table balance_sheet (BS_ID INTEGER
BS_ID 項目代碼 BS_PID 項目父代碼 BS_Name 項目名稱 BS_VALUE 數據列
插入測試數據
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
insert into balance_sheet values(
commit;
顯示全部數據
select bs_name
connect by prior bs_id = bs_pid
start with bs_pid =
data:image/s3,"s3://crabby-images/87501/87501ff08e8331596cb2590ecf6c4a335e5627f3" alt=""
顯示一個節點的數據
select bs_name
connect by prior bs_id = bs_pid
start with bs_pid =
其中connect by 定義父子連接關系
start with 定義開始節點
data:image/s3,"s3://crabby-images/a8c67/a8c67fd0fdd48c91ebb8eaa392b4740f9f57907e" alt=""
(流動資產節點數據)
顯示層次結構
select (case when level =
when level =
end ) bs_name
connect by prior bs_id = bs_pid
start with bs_pid =
其中引用了level字段
data:image/s3,"s3://crabby-images/354ef/354efed0b39a48c1c193265f60b6d495d57e14d9" alt=""
(根據層次來實現縮進風格)
層次內排序
select (case when level =
when level =
end ) bs_name
connect by prior bs_id = bs_pid
start with bs_id =
ORDER SIBLINGS BY bs_value desc
data:image/s3,"s3://crabby-images/0691e/0691e914ff8553e92f5db49d34301d19e92ef99d" alt=""
select
ltrim(sys_connect_by_path( BS_Name
(case when level =
when level =
end ) bs_name
from balance_sheet
connect by prior bs_id = bs_pid
start with bs_pid =
data:image/s3,"s3://crabby-images/022c8/022c8fabb724918e1f3d84d65d6528c2bfab5d5a" alt=""
層次計算
這裡層次計算是指根據父子節點關系進行匯總
但是在財務報表父指標
例如
長期資產 = 中長期貸款 – 貸款呆賬准備 +固定資產淨值 +其他長期資產
為了實現這種情況
這樣 父節點 = SUM(子節點 * Direction)
SELECT
SUBSTR (PATH
sum(bs_value * bs_dir)
FROM (SELECT BS_ID
bs_value
FROM balance_sheet
CONNECT BY PRIOR bs_id = bs_pid
START WITH bs_pid =
group by SUBSTR (PATH
data:image/s3,"s3://crabby-images/9a9d4/9a9d4a9891c0f065c2e97fe62a17d7317a19ef8f" alt=""
竟然有意外的收獲
數據的最後一行是對所有原表第一層節點的疊加
BS_LParID
From:http://tw.wingwit.com/Article/program/Oracle/201311/18351.html