当前位置:首页 » 编程语言 » plsql循环执行
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

plsql循环执行

发布时间: 2023-06-14 20:41:14

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

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;

按照你的思路写的,具体需要根据你自己实际需求修改扩充一下

‘贰’ plsql 里,我有一个循环执行语句,如何做才能每执行一次,输出信息我现在发现是全部执行完成后才

把输出语句放在循环中间执行就可以了。

例:
for c in cursor loop
【业务逻辑】
dbms_output.put_line('此处循环输出结果');
end loop;

‘叁’ 用PLSQL连接orcale ,出现重复执行SQL语句!!!!

很不幸,我遇到和你相同的情况,试了好多种办法,之前是安装在F盘的,重新安装也不起作用.最的将它安装C盘,莫名其妙的好了,我也不知道什么原因.

‘肆’ plsql中如果我定义一个游标,然后打开这个游标,然后loop循环把查询出来的数据全部插入自己定义的表中

使用子查询执行直接装载
insert /*+APPEND */ into employee(empno,ename,sal,deptno)
select empno,ename,sal,deptno from emp where deptno=20;

注意,要加上“/*+APPEND */",它表示直接装载方式,当装载大批量数据时,这是种做法效率很高。

‘伍’ plsql for循环如何控制每行输出的个数

把输出语句放在循环中间执行就可以了。
例:
for
c
in
cursor
loop

业务逻辑

dbms_output
.put_line('此处循环输出结果');
end
loop;

‘陆’ PL/SQL如何实现并行执行存储过程

实现的话,这个得看你需求才能写,一般语法也不是特别麻烦,多学学循环,动态sql的基本可以应付一切了。
执行的话,一般开个sql窗口
begin
存储过程名(参数1,参数2……);
end;如果没有参数,括号里一堆就不用写了,然后执行即可。