这里注意增删改以后要对做的操作进行commit提交,如果操作失败则rollback回滚刚才的操作。
3、参数游标:
在定义游标时加入参数的游标,可以配合游标for循环快速找到需要的数据。这里先讲一下游标for循环
A、游标FOR循环:
隐含的执行了打开提取关闭数据,代码精简很多。Expression:
FOR table_record IN table_cursor LOOP
STATEMENT;
END LOOP;
Example:使用游标For循环打印输出员工信息:
DECLARE CURSOR emp_cursor IS SELECT empno,ename,job FROM emp; BEGIN FOR emp_record IN emp_cursor LOOP DBMS_OUTPUT.PUT_LINE('员工号:'||emp_record.empno||'员工姓名'||emp_record.ename||'员工职位'||emp_record.job); END LOOP; END;
这里游标FOR循环省去了对于取到的数据的变量的命名和赋值,同时如果全部打印则不用写循环条件,代码精简了很多。
如果想让代码更加精简,则可以去掉对游标的声明引入子查询即可,操作如下。
BEGIN FOR emp_record IN (SELECT empno,ename,job FROM emp) LOOP DBMS_OUTPUT.PUT_LINE('员工号:'||emp_record.empno||'员工姓名'||emp_record.ename||'员工职位'||emp_record.job); END LOOP; END;
代码更加精简,得到的结果相同。和隐式游标是不是有点像,但隐式游标主要用于的是单行select和dml语句的操作,注意2者用法的区别。
下面继续参数游标的实例:
Example:输入部门号打印员工信息:
DECLARE CURSOR emp_cursor(dno NUMBER)IS SELECT empno,ename,job FROM emp WHERE deptno=dno; BEGIN FOR emp_record IN emp_cursor(&dno) LOOP DBMS_OUTPUT.PUT_LINE('员工号'||emp_record.empno||'姓名'||emp_record.ename||'职位'||emp_record.job); END LOOP; END;
这里既然有参数,那么必然会有对游标的声明,在结合游标FOR循环快速超找所需要的数据。
三、使用游标修改数据的注意事项
1、使用游标修改数据时,为防止他人在自己操作数据时对数据进行修改,oracle提供for update子句进行加锁。
同时在你使用update或delete时,必须使用where current of+name_cursor语句,以及在最后记得提交。如果是级联操作则可以使用for update of 来进行相关表的加锁。
Example1:对职位是PRESIDENT的员工加1000工资,MANAGER的人加500工资
CREATE TABLE emp_new AS SELECT * FROM emp;
DECLARE CURSOR empnew_cursor IS SELECT ename,job FROM emp_new FOR UPDATE; BEGIN FOR empnew_record IN empnew_cursor LOOP DBMS_OUTPUT.PUT_LINE('姓名'||empnew_record.ename||'职位'||empnew_record.job); IF empnew_record.job='PRESIDENT' THEN UPDATE emp_new SET sal=sal+1000 WHERE CURRENT OF empnew_cursor; ELSIF empnew_record.job='MANAGER' THEN UPDATE emp_new SET sal=sal+500 WHERE CURRENT OF empnew_cursor; END IF; END LOOP; COMMIT; END;
可以看到这里工资有了相应的变化。至此,Oracle游标解析完毕,总而言之,游标只是作为我们从数据库中提取出来的一部分数据,我们针对这个结果集做一系列的操作。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。