pl/sql存储过程的递归调用,树形数据的展示

--pl/sql的树状结构的存储与展示
drop table article;
create table article(
  id number primary key, --id
  cont varchar2(4000),
  pid number,           --父id
  isleaf number(1),     --0代表非叶子节点,1代表叶子节点
  alevle number(2)      --深度,层级
);

insert into article values(1,'蚂蚁大战大象',0,0,0);
insert into article values(2,'大象被打趴下了',1,0,1);
insert into article values(3,'蚂蚁也不好过',2,1,2);
insert into article values(4,'瞎说',2,0,2);
insert into article values(5,'没有瞎说',4,1,3);
insert into article values(6,'怎么可能',1,0,1);
insert into article values(7,'怎么没有可能',6,1,2);
insert into article values(8,'可能性很大的',6,1,2);
insert into article values(9,'大象进医院了',2,0,2);
insert into article values(10,'护士是蚂蚁',9,1,3);
commit;

--pl/sql存储过程的递归调用,树形数据的展示
--sp_tree_recur(v_pid,v_level);--树的root_id;
create or replace procedure sp_tree_recur(v_pid article.pid%type,v_level binary_integer) is
cursor c is select * from article where pid=v_pid;
v_format_string  varchar2(10000):='';
begin
    for c_article in c loop
        begin
          for i in 1..v_level loop--深度,层级
            v_format_string:=v_format_string||'****';
          end loop;
          dbms_output.put_line(v_format_string||c_article.cont);
          if(c_article.isleaf = 0) then --非叶子节点,继续递归
             sp_tree_recur(c_article.id,c_article.ALEVLE+1);
          end if;
        end;
    end loop;
end;


评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值