oracle 树状结构递归 PL/SQL输出控制 包括空格输出控制

树状结构

存储过程中通过递归构建,类似BBS回帖显示,代码共三段:

建表,插入数据,创建存储过程显示;

1.
create table article
(
id number primary key,
cont varchar2(4000),
pid number,
idleaf number(1), --0为非叶子节点,1为叶子节点
alevel number(2)
);

2.

insert into article values(1,‘蚂蚁大战大象‘,0,0,0);
insert into article values(2,‘大象被打趴下了‘,1,0,1);
insert into article values(3,‘蚂蚁也不好过‘,1,0,1);
insert into article values(4,‘瞎说‘,2,1,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);

3.

create or replace procedure tree(v_pid article.pid%type,v_alevel article.alevel%type)
is
  cursor c is select * from article where pid=v_pid;
  v_str varchar2(2048) :=‘ ‘;
begin
  for i in 0..v_alevel loop
  v_str :=v_str||‘      ‘;
end loop;
  for v_article in c loop dbms_output.put_line(v_str||v_article.cont);
  if (v_article.isleaf =0) then
    tree(v_article.id,v_article.alevel);
  end if;
  end loop;
  end;

结果前面的N*4个空格不显示:

设置空格输出后,问题解决:

其它问题:第一层的输出前不应该带空格,设置初始字符串为空,i从1开始。

设置 oracle sqlplus DBMS_OUTPUT.put_line

下面内容摘录自

http://blog.csdn.net/wbj1234566/article/details/2557515

1 设置DBMS_OUTPUT.put_line输出显示     SET SERVEROUTPUT ON

2 关闭DBMS_OUTPUT.put_line输出显示     SET SERVEROUTPUT OFF

3 设置DBMS_OUTPUT缓冲区大小     SET SERVEROUTPUT ON SIZE number(1000)

4 设置只显示DBMS_OUTPUT默认的长度     SET SERVEROUTPUT ON FORMAT TRUNCATED

5 设置空格的输出     SET SERVEROUTPUT ON FORMAT WRAPPED

6 取消空格的输出     SET SERVEROUTPUT ON FORMAT WORD_WRAPPED

时间: 2024-10-12 03:15:19

oracle 树状结构递归 PL/SQL输出控制 包括空格输出控制的相关文章

树 List Leaves 【用数组模拟了树状结构建树+搜索叶子节点+按照特殊规律输出每个叶子节点】

Given a tree, you are supposed to list all the leaves in the order of top down, and left to right. Input Specification: Each input file contains one test case. For each case, the first line gives a positive integer N (≤10) which is the total number o

lua 如何输出树状结构的table?

为了让游戏前端数据输出更加条理,做了一个简单树状结构来打印数据. ccmlog.lua local function __tostring(value, indent, vmap) local str = '' indent = indent or '' vmap = vmap or {} --递归结束条件 if (type(value) ~= 'table') then if (type(value) == 'string') then --字符串 str = string.format("[

lua 怎样输出树状结构的table?

为了让游戏前端数据输出更加条理,做了一个简单树状结构来打印数据. ccmlog.lua local function __tostring(value, indent, vmap) local str = '' indent = indent or '' vmap = vmap or {} --递归结束条件 if (type(value) ~= 'table') then if (type(value) == 'string') then --字符串 str = string.format("[

在Silverlight中使用HierarchicalDataTemplate为TreeView实现递归树状结构

将实体绑定到TreeView控件,实现树状结构的显示,如下图所示.这个功能通过HierarchicalDataTemplate实现. ? 1. 业务实体 作为举例,我定义了一个大家都很熟悉的Folder类型,即文件夹.我们都知道,文件夹又可以包含子文件夹,而且可以多层嵌套.所以,这是一个递归的结构体. public class Folder { public string Name { get; set; } public ObservableCollection<Folder> Folder

c# 递归、树状结构

1.树状结构 treeView.Nodes.Clear(); TreeNode tree = new TreeNode(); tree.Text = "字母"; treeView.Nodes.Add(tree); // tree.Nodes.Add("A"); TreeNode tree1 = new TreeNode(); tree1.Text = "汉字"; treeView.Nodes.Add(tree1); TreeNode a = ne

使用Map辅助拼装树状结构,消除递归调用

目前菜单或其他树状结构在数据库中的存储,多数是以一个parentid作为关联字段,以一维形式存储.使用时全部查询出来,然后在内存中拼装成树状结构.现在主要涉及的是拼装方法的问题. 一般可以进行 递归调用来实现 过程如下:1.首先找到根节(s)点即没有上级节点的元素 2.根据找到的节点的id,遍历数据,查看parentid为此id的元素 将其 放到此元素的childlist中去3.对此元素的childlist 重复步骤2 2-3这个步骤的重复 一般通过递归来实现. 我采用的方法,是使用map作为辅

oracle入门(6)——PL/SQL常用语法

[本文介绍] 本文不是”语法大全“,只是记录下作项目里自己常用的一些语法.方便查询. [语法] [输出]   (1)输出语法 DBMS_OUTPUT.PUT_LINE( ) [定义]   (1)定义变量: ...... as 变量名 类型(长度) begin ...... 例如: (2)定义变量 ,类型 依赖其他变量的类型 例如: 这样,改了name的类型,returnValue类型也跟着改变. (3)自定义类型(类似C语言的结构体)每次只能拿一条数据,不然会的报错. 例如: (4)以“表”做为

Day03处理上级部门(树状结构)和用户管理

系统管理:部门管理-处理上级部门 添加或者修改时,上级部门的格式如图:.解决此功能将面临两个问题:1.将所有部门名称以下拉选的形式展示出来2.以树状结构展示.在此我们先解决问题1. 在添加页面中展示所有部门名称,并完成添加功能 DepartmentAction: public String addUI() throws Exception { //准备数据 List<Department> departmentList = departmentService.findAll(); Action

Oracle 学习笔记 17 -- 异常处理(PL/SQL)

程序在执行过程中出现异常是正常的,在程序的编写过程中出现异常也是不可避免的.但是要有相应的异常处理的机 制,来保证程序的正常执行.PL/SQL程序执行过程中出现的错误,称为异常.一个优秀的程序都应该能够正确处理 各种出错的情况,并尽可能的从错误中恢复.PL/SQL提供了异常处理机制. 概念: 异常处理(exception)是用来处理正常执行过程中未预料的事件,程序块的异常处理定义的错误和自定义的错误, 由于PL/SQL程序块一旦产生异常而没有指出如何处理时,程序就会异常的终止. 有三种类型的错误