存储过程中遍历游标的三种方式(For,Fetch,While)
时间:2019-02-18 13:04 来源:linux.it.net.cn 作者:IT
游标其实就是结果集,而在实际开发中,常用的是for循环去遍历游标。直接上代码吧。
create or replace procedure myprocedure is
CURSOR CUR_TEST IS --声明显式游标
SELECT ECODE,ENAME
FROM EMP;
CUR CUR_TEST%ROWTYPE; --定义游标变量,该变量的类型为基于游标C_EMP的记录
BEGIN
--For 循环
FOR CUR IN CUR_TEST LOOP
--循环体
DBMS_OUTPUT.PUT_LINE('员工编号:'||CUR.ECODE ||'员工姓名:'|| CUR.ENAME);
END LOOP;
--Fetch 循环
OPEN CUR_TEST;--必须要明确的打开和关闭游标
LOOP
FETCH CUR_TEST INTO CUR;
EXIT WHEN CUR_TEST%NOTFOUND;
--循环体
DBMS_OUTPUT.PUT_LINE('员工编号:'||CUR.ECODE ||'员工姓名:'|| CUR.ENAME);
END LOOP;
CLOSE C_EMP;
--While 循环
OPEN CUR_TEST;--必须要明确的打开和关闭游标
FETCH CUR_TEST INTO CUR;
WHILE CUR_TEST%FOUND LOOP
--循环体
DBMS_OUTPUT.PUT_LINE('员工编号:'||CUR.ECODE ||'员工姓名:'|| CUR.ENAME);
FETCH CUR_TEST INTO CUR;
END LOOP;
CLOSE C_EMP;
END myprocedure;
使用For循环的有什么好处?
从代码中可以很明显的看出:1、使用for循环不需要关注游标是否打开或关闭。
2、for循环会自动将数据fetch到记录型变量
3、for循环不需要关注何时要退出,也就是不需要写退出满足条件。遍历完成就会退出。
所以for循环是用来循环游标的最好方法。高效,简洁,安全。
(责任编辑:IT)
游标其实就是结果集,而在实际开发中,常用的是for循环去遍历游标。直接上代码吧。 create or replace procedure myprocedure is CURSOR CUR_TEST IS --声明显式游标 SELECT ECODE,ENAME FROM EMP; CUR CUR_TEST%ROWTYPE; --定义游标变量,该变量的类型为基于游标C_EMP的记录 BEGIN --For 循环 FOR CUR IN CUR_TEST LOOP --循环体 DBMS_OUTPUT.PUT_LINE('员工编号:'||CUR.ECODE ||'员工姓名:'|| CUR.ENAME); END LOOP; --Fetch 循环 OPEN CUR_TEST;--必须要明确的打开和关闭游标 LOOP FETCH CUR_TEST INTO CUR; EXIT WHEN CUR_TEST%NOTFOUND; --循环体 DBMS_OUTPUT.PUT_LINE('员工编号:'||CUR.ECODE ||'员工姓名:'|| CUR.ENAME); END LOOP; CLOSE C_EMP; --While 循环 OPEN CUR_TEST;--必须要明确的打开和关闭游标 FETCH CUR_TEST INTO CUR; WHILE CUR_TEST%FOUND LOOP --循环体 DBMS_OUTPUT.PUT_LINE('员工编号:'||CUR.ECODE ||'员工姓名:'|| CUR.ENAME); FETCH CUR_TEST INTO CUR; END LOOP; CLOSE C_EMP; END myprocedure; 使用For循环的有什么好处? 从代码中可以很明显的看出:1、使用for循环不需要关注游标是否打开或关闭。 2、for循环会自动将数据fetch到记录型变量 3、for循环不需要关注何时要退出,也就是不需要写退出满足条件。遍历完成就会退出。 所以for循环是用来循环游标的最好方法。高效,简洁,安全。 (责任编辑:IT) |