关闭

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

1612人阅读 评论(2) 收藏 举报
分类:
--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;


1
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

oracle父子结构表递归查询sql语句

select j.*,j.rowid from SJ_LIB_CATEGORY j start with j.id ='c8759461-9b5e-4375-90f7-94f9c84dbe51' c...
  • zhengxiangwen
  • zhengxiangwen
  • 2014-10-30 15:13
  • 3105

使用oracle 的 PL/Sql 定时执行一个存储过程

今天创建job  begin  dbms_job.submit(:job1,'test',sysdate,'sysdate+5/1440');  end;  / * 第 1 行出现错误...
  • u011680118
  • u011680118
  • 2016-09-01 20:36
  • 1585

[PL/SQL]使用存储过程实现导出指定数据到文件(仿EXP)

由于EXP不能直接导出表的指定字段(其实也可通过CREATE TABLE  tablename AS SELECT...来间接实现),故自己写了个存储来实现这个功能. create or repla...
  • edcvf3
  • edcvf3
  • 2013-03-04 14:09
  • 2412

[PL/SQL]导入文件内的数据到数据库(针对本博的导出存储过程)

create or replace procedure IMP_DATA ( file_name in varchar2 --要导入的文件名,包含路径(如:d:\test\exp_0003.txt...
  • edcvf3
  • edcvf3
  • 2013-03-07 16:49
  • 1447

pl/sql存储过程返回record类型和集合类型的结果,Java里如何调用呢

pl/sql存储过程返回record类型和集合类型的结果,Java里如何调用呢 比如这样的数据类型定义: CREATE OR REPLACE PACKAGE SmsService  IS  Ty...
  • goodlisf
  • goodlisf
  • 2016-03-31 15:58
  • 1802

Oracle集合类型输出参数的PL/SQL存储过程及其Java调用

现在的java的数据库-关系映射技术似乎不提倡用存储过程,其实存储过程更能发挥数据库的效率。 1  引言 存储过程因其执行效率高、与事务处理的结合、运行更安全等优点,在数据库应用程序中被广泛采用。...
  • huang798807481
  • huang798807481
  • 2012-04-17 15:28
  • 794

关于oracle中PL/SQL语句,即存储过程的写法和调用。

1.什么是PL/SQL,有什么作用   --Procedure Language/SQL 过程语言+SQL   --PL/SQL是Oracle数据库内部存储和运行     一段程序   --P...
  • qq_16872369
  • qq_16872369
  • 2015-01-20 15:57
  • 841

PL/Sql 中创建、调试、调用存储过程

点击打开链接http://www.cnblogs.com/gossip/archive/2011/09/23/2186232.html 存储过程   所用函数说明   功能:求和与差...
  • free_shy
  • free_shy
  • 2016-03-21 20:06
  • 193

PL/Sql 中创建、调试、调用存储过程

存储过程   所用函数说明   功能:求和与差   原形:GetSumAndSub(p1 in number , p2 in number ,m out number , b out numbe...
  • cc_yy_zh
  • cc_yy_zh
  • 2016-08-02 17:26
  • 179

[转载]pl/sql动态调用带参数的存储过程

以下内容来自:http://blog.itpub.net/658202/viewspace-1032467/ 说明:proc_one、proc_two、proc_three用来模拟三个proce...
  • zfr046
  • zfr046
  • 2014-01-02 21:01
  • 479