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

原创 2016年06月01日 00:46:03
--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;


版权声明:本文为博主原创文章,未经博主允许不得转载。 举报

相关文章推荐

oracle存储过程的递归调用

心里知道有这么回事,但很少在实践中用到,下面是一个查找父地址的过程。 CREATE OR REPLACE FUNCTION F_CALLPARENTARDADDRESS(V_ARDA...

存储过程实现递归算法

以经典的阶乘算法为例。Oracle:[sql] view plain copycreate or replace procedure factorial(n in number, b out ...

我是如何成为一名python大咖的?

人生苦短,都说必须python,那么我分享下我是如何从小白成为Python资深开发者的吧。2014年我大学刚毕业..

递归用函数、存储过程实现的效果

--測試  create table ta (项目 varchar(20),上级项目 varchar(20),num int)insert taselect A, ,100 union allsele...
  • roy_88
  • roy_88
  • 2006-12-24 18:21
  • 4521

SQL SERVER 存储过程的天然递归

有几次,我编写或修改存储过程的时候,为图方便,在末尾随手写上 执行这个存储过程 的语句,比如ALTER PROCEDURE prd_GetData @Top INT = 10; AS SELECT...

SQL_存储过程CET递归查询获得树的叶子节点

USE [SooilSemanticsDB] GO /****** Object: StoredProcedure [dbo].[usp_Semantics_GetLeaf] Script D...

存储过程利用递归查找出树节点以及所有子节点

2015-1-29星期四 调用存储过程,查询所有的圈子 call circles (); 与回帖有关的储存过程 drop PROCEDURE if EXISTS replies; d...

PLSQL中递归树的总结

一、siblings 1.回望关系“树”,这棵树中的B和C是亲兄弟,F和G是亲兄弟。注意,D和E不是亲兄弟,最多也就算是堂兄弟,“亲兄弟排序”功能对他们无效。       A      ...

START WITH...CONNECT BY PRIOR用法

select *    from dept   start with id = 1  connect by prior id = parent_id;

PL/SQL存储函数,存储过程

一.存储过程和存储函数 存储过程和存储函数跟我们知道的表、视图、索引、序列、同义词等一样是我们数据中的对象。 1.1什么是存储过程和存储函数: 指存储在数据库中供所有的用户程序调用的 子程序叫存储...

18-Oracle学习_存储过程-递归-树状结构的存储与展示

一, 表 create table article ( id number primary key, cont varchar2(4000), pid number, ...
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)