oracle在存储过程中调用存储过程
来源:互联网 发布:中外文化差异知乎 编辑:程序博客网 时间:2024/04/30 17:40
实际项目当中经常需要在一个存储过程中调用另一个存储过程返回的游标,本文列举了两种情况讲述具体的操作方法。
第一种情况返回的游标是具体的某个表或试图,如:
CREATE OR REPLACE PROCEDURE P_TESTA (
PRESULT OUT SYS_REFCURSOR
)
AS
BEGIN
OPEN PRESULT FOR SELECT * FROM USERS;
END P_TESTA;
PRESULT OUT SYS_REFCURSOR
)
AS
BEGIN
OPEN PRESULT FOR SELECT * FROM USERS;
END P_TESTA;
其中USERS就是数据库中一个表。在调用的时候只要声明一个该表的ROWTYPE类型就可以了:
代码如下:
CREATE OR REPLACE PROCEDURE P_TESTB
AS
VARCURSOR SYS_REFCURSOR;
R USERS%ROWTYPE;
BEGIN
P_TESTA(VARCURSOR);
LOOP
FETCH VARCURSOR INTO R;
EXIT WHEN VARCURSOR%NOTFOUND;
DBMS_OUTPUT.PUT_LINE(R.NAME);
END LOOP;
END P_TESTB;
第二种情况,我们返回的不是表的所有的列,或许只是其中一列或两列,如:
代码如下:
CREATE OR REPLACE PROCEDURE P_TESTA (
PRESULT OUT SYS_REFCURSOR
)
AS
BEGIN
OPEN PRESULT FOR SELECT ID,NAME FROM USERS;
END P_TESTA;
这里我们只返回了USERS表的ID,NAME这两个列,那么调用的时候也必须做相应的修改:
代码如下:
CREATE OR REPLACE PROCEDURE P_TESTB
AS
VARCURSOR SYS_REFCURSOR;
CURSOR TMPCURSOR IS SELECT ID,NAME FROM USERS WHERE ROWNUM=1;
R TMPCURSOR%ROWTYPE;
BEGIN
P_TESTA(VARCURSOR);
LOOP
FETCH VARCURSOR INTO R;
EXIT WHEN VARCURSOR%NOTFOUND;
DBMS_OUTPUT.PUT_LINE(R.ID);
END LOOP;
END P_TESTB;
与之前不同的是我们声明了一个游标类型的变量TMPCURSOR ,注意TMPCURSOR 的结构必须与存储过程P_TESTA 返回的游标结构一致,否则就会出现错误。同理只要保持两个游标类型结构一致,就可以实现自由调用。
- oracle在存储过程中调用存储过程
- oracle 存储过程中调用存储过程
- 在java中调用Oracle存储过程
- 在java中调用Oracle存储过程
- 在 MyBatis 中调用Oracle存储过程
- oracle--在java中调用存储过程和存储函数
- 在应用程序中调用Oracle存储过程和存储函数
- oracle中调用存储过程
- oracle存储过程,存储过程,以及在java中的调用
- oracle调用存储过程
- Oracle调用存储过程
- oracle调用存储过程
- oracle 存储过程调用
- 如何创建oracle存储过程及在jsp中调用
- 怎样在java代码中调用Oracle的存储过程
- oracle在job中调用带有参数的存储过程
- 在 PL/SQL 中调用存储过程 oracle
- oracle存储过程分页以及在java中调用
- 关于使用count(X) 函数的说明(附加:关于null的说明以及和0的区别)
- android JSON解析
- maven pom.xml详解
- solr 管理界面
- The Adapter of ListView: Just adapt data to view, don’t do anything else
- oracle在存储过程中调用存储过程
- 点击查看大图,大图上带上一张 、下一张功能(粗糙版)
- 基本的solr概念
- ArcGIS Api For Flex 划选查询功能的实现
- What's the difference between Git Revert, Checkout and Reset?
- 苏菲的世界开发商的方便快捷
- Android之Handler用法总结
- switch 与 if else 效率分析与总结
- java 编译命令