oracle 过程 调用本身

我们在删除父节点时需要删除子节点,子节点的子节点也要删除,这样就需要循环调用该函数,直到没有子节点的时候。

如下打印出某一节点下的所有子节点

表结构就是一个树形结构的传统结构。

CREATE OR REPLACE

PROCEDURE "DeleteNode" (deleteNodeID IN VARCHAR2)

AS

CURSOR children_cursor IS

SELECT "NodeID" FROM "Organize" WHERE "ParentID" = deleteNodeID;

BEGIN

FOR childIDs IN children_cursor LOOP

--调用本身

declare

BEGIN

SYS."DeleteNode"(childIDs."NodeID");

END;

--调用本身

DBMS_OUTPUT.PUT_LINE(childIDs."NodeID");

delete FROM "Organize" WHERE "NodeID"=childIDs."NodeID";

delete FROM "Node" WHERE "ID"=childIDs."NodeID";

END LOOP;

delete FROM "Organize" WHERE "NodeID"=deleteNodeID;

delete FROM "Node" WHERE "ID"=deleteNodeID;

END;

时间: 2024-12-15 01:36:28

oracle 过程 调用本身的相关文章

从汇编角度分析C语言的过程调用

?更多技术干货请戳:听云博客 基本术语定义 1.系统栈(system stack)是一个内存区,位于进程地址空间的末端. 2.在将数据压栈时,栈是自顶向下增长的,该内存区用于函数的局部变量提供内存.它也支持在调用函数时传递参数. 3.如果调用了嵌套的过程,栈会自上而下增长,并接受新的活动记录(activation record)来保存一个过程所需的所有数据. 4.当前执行过程的活动记录,由标记顶部位置的帧指针(frame point)和标记底部位置的栈指针(stack point)定义. 5.在

RPC-远程过程调用协议

远程过程调用协议 同义词 RPC一般指远程过程调用协议 RPC(Remote Procedure Call Protocol)——远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议.RPC协议假定某些传输协议的存在,如TCP或UDP,为通信程序之间携带信息数据.在OSI网络通信模型中,RPC跨越了传输层和应用层.RPC使得开发包括网络分布式多程序在内的应用程序更加容易. RPC采用客户机/服务器模式.请求程序就是一个客户机,而服务提供程序就是一个服务器.

IPC: 过程调用

##################################################### 过程调用: 过程调用分为: 1.本地过程调用 2.远程过程调用(RPC) 远程过程调用有两种接口: 1.单台主机上的远程过程调用(solaris门) 2.主机间的远程过程调用(Sun RPC) ----------------------------------------------------------- Sun RPC sun rpc属于posix标准. -------------

Wayland中的跨进程过程调用浅析

原文地址:http://blog.csdn.net/jinzhuojun/article/details/40264449 Wayland协议主要提供了Client端应用与Server端Compositor的通信机制,Weston是Server端Compositor的一个参考实现.Wayland协议中最基础的是提供了一种面向对象的跨进程过程调用的功能,在作用上类似于Android中的Binder.与Binder不同的是,在Wayland中Client和Server底层通过domain socke

Oracle定时器调用存储过程

1. 创建表 create table job_table(run_time date); 2. 创建存储过程 create or replace procedure job_proc is begin insert into job_table (run_time) values (sysdate); end; 3. 创建定时器job,并且指定为一分钟执行一次 declare job number; begin dbms_job.submit(job, 'job_proc;', sysdate

64位 SQL Server2008链接访问Oracle 过程汇总解决方法记录

64位 SQL Server2008链接访问Oracle 过程汇总解决方法记录 经过几天不停的网上找资料,实验,终于联通了. 环境:系统:win 2008 ,SqlServer2008 R2, 连接Oracle10g 在SqlServer2008 R2机器上需要安装Oracle客户端32位和64位两个,然后配置连接别名.设置注册表.详细情况见下面 1.错误1 ------------------------------------------------ 64位机器上建立OLE_DB链接报错 报

IAA32过程调用寄存器的保护规则

由于操作系统中的共享性质,所以,寄存器也就成为了各个进程或者过程共享资源的一种.那么发生过程 调用的时候,如果调用者要用到一个寄存器里面的值,但是这个寄存器的内容很可能在被调用者运行过程中修改,那么我们就要在被调用过程执行之前,对该寄存器里面的内容进行保护,以至于不会出错,寄存器的保护规则也是因为程序的不可再现性而存在的. 在IA32上,实行了一个统一的寄存器保护规则.首先,我们要看一下,计算机中有多少个比较重要的寄存器 (偷偷懒我就不写寄存器前面的百分号了O(∩_∩)O) eax 这个寄存器属

ARM过程调用标准---APCS简单介绍

介绍 APCS,ARM 过程调用标准(ARM Procedure Call Standard),提供了紧凑的编写例程的一种机制,定义的例程能够与其它例程交织在一起.最显著的一点是对这些例程来自哪里没有明白的限制.它们能够编译自 C. Pascal.也能够是用汇编语言写成的. APCS 定义了: 对寄存器使用的限制. 使用栈的惯例. 在函数调用之间传递/返回參数. 能够被'回溯'的基于栈的结构的格式,用来提供从失败点到程序入口的函数(和给予的參数)的列表. APCS 不一个单一的给定标准,而是一系

Wayland (三) Wayland中的跨进程过程调用浅析 [FW]

原文地址:http://blog.csdn.net/jinzhuojun/article/details/40264449 Wayland协议主要提供了Client端应用与Server端Compositor的通信机制,Weston是Server端Compositor的一个參考实现.Wayland协议中最基础的是提供了一种面向对象的跨进程过程调用的功能,在作用上类似于Android中的Binder.与Binder不同的是,在Wayland中Client和Server底层通过domain socke