在oracle中创建一个存储过程,来循环获取 a表中存放的查询sql语句 并一条一条的执行该sql语句并存下来。

由于小弟没有基础,能否请哪位高手指点的具体点,最好能有类似的例子给出一个并细细讲解一下~万分感激了。ps:在plsql中调用过程。... 由于小弟没有基础,能否请哪位高手指点的具体点,最好能有类似的例子给出一个并细细讲解一下~万分感激了。
ps:在plsql中调用过程。
展开
 我来答
百度网友143bbe3
2012-12-28 · TA获得超过121个赞
知道答主
回答量:50
采纳率:0%
帮助的人:47.9万
展开全部
CREATE OR REPLACE PACKAGE BODY PKG_A_TESTPACKAGE IS
PROCEDURE PKG_A_TESTPROCEDURE(PRM_参数 IN VARCHAR2,
PRM_返回值 OUT NUMBER,
PRM_错误信息 OUT VARCHAR2) IS
TYPE CURSOR_TYPE IS REF CURSOR;
CUR_SQL CURSOR_TYPE;

TYPE TYP_REC_INFO IS RECORD(
COLUMN VARCHAR2(1000));
LREC_INFO TYP_REC_INFO;

BEGIN
PRM_返回值 := 0;

-- 循环获取查询SQL
FOR REC_SQL IN (SELECT 查询SQL FROM 存放SQL的表 WHERE 条件) LOOP

BEGIN
OPEN CUR_SQL FOR REC_SQL.查询SQL;
LOOP
-- 获取查询的信息
FETCH CUR_SQL
INTO LREC_INFO; --存放查询结果,这里只针对单列的查询结果

-- 如果没有取到退出
EXIT WHEN CUR_SQL%NOTFOUND;

END LOOP;
CLOSE CUR_SQL;
END;

END LOOP;

EXCEPTION
WHEN OTHERS THEN
PRM_返回值 := -1;
PRM_错误信息 := '执行PKG_A_TESTPROCEDURE出错';
END PKG_A_TESTPROCEDURE;
END PKG_A_TESTPACKAGE;

按照你的思路写的,具体需要根据你自己实际需求修改扩充一下
追问
哇,非常感谢。能否简单说下
PRM_返回值 := 0;和 PRM_返回值 := -1;是个什么用法。大概用途是什么~谢谢了~
追答
PRM_返回值 := 0;和 PRM_返回值   := -1;
这个返回值为了捕捉过程内的异常,‘0’为正常‘-1’为出错
大洋爱生活
2012-12-27
知道答主
回答量:88
采纳率:0%
帮助的人:20.1万
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式