游标其实就是结果集,而在实际开发中,常用的是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) |