Oracle游标的运用实例详解

2019-01-02 14:58:07来历:作者:人点击

共享

什么是游标?

①从表中检索出成果集,从中每次指向一条记载进行交互的机制。

②联络数据库中的操作是在完好的行调集上履行的。

由 SELECT 句子回来的行调集包含满意该句子的 WHERE 子句所列条件的一切行。由该句子回来完好的行调集叫做成果集。

使用程序,尤其是互动和在线使用程序,把完好的成果集作为一个单元处理并不总是有用的。

这些使用程序需求一种机制来一次处理一行或接连的几行。而游标是对供给这一机制的成果集的扩展。

游标是经过游标库来完成的。游标库是常常作为数据库体系或数据拜访 API 的一部分而得以完成的软件,用来办理从数据源回来的数据的特点(成果集)。这些特点包含并发办理、在成果会集的方位、回来的行数,以及是否能够在成果会集向前和/或向后移动(可翻滚性)。

游标盯梢成果会集的方位,并答应对成果集逐行履行多个操作,在这个进程中或许回来至原始表,也或许不回来至原始表。

换句话说,游标从概念上讲根据数据库的表回来成果集。

由于它指示成果会集的当时方位 ,就像计算机屏幕上的光标指示当时方位相同,“游标”由此得名。

游标有什么效果?

①指定成果会集特定行的方位。

②根据当时的成果集方位检索一行或接连的几行。

③在成果集的当时方位修正行中的数据。

④对其他用户所做的数据更改界说不同的敏感性等级。

⑤能够以的办法拜访数据库。

导言

本节对Oracle中的游标进行具体解说。本节所举实例来历Oracle中scott用户下的emp表dept表:

一、游标:

1、概念:

游标的实质是一个成果集resultset,首要用来暂时存储从数据库中提取出来的数据块。

二、游标的分类:

1、显式游标:

由用户界说,需求的操作:界说游标、翻开游标、提取数据、封闭游标,首要用于对查询句子的处理。

特点:%FOUND %NOTFOUND %ISOPEN %ROWCOUNT

Example:打印emp表的职工信息

DECLARE CURSOR emp_cursor IS SELECT empno,ename,job FROM emp; v_empno emp.empno%TYPE; v_name emp.ename%TYPE; v_job emp.job%TYPE;BEGIN OPEN emp_cursor; LOOP FETCH emp_cursor INTO v_empno,v_name,v_job; DBMS_OUTPUT.PUT_LINE('职工号为:'||v_empno||'名字是'||v_name||'职位:'||v_job); EXIT WHEN emp_cursor%NOTFOUND; END LOOP; CLOSE emp_cursor;END;

这儿严厉依照显现游标的书写规矩:DECLARE emp_cursor界说游标OPEN emp_cursor翻开游标FETCH emp_cursor INTO...提取数据CLOSE emp_cursor封闭游标,由于提取出来的数据归于多行,所以经过loop循环打印即可。

Example2:查验游标是否翻开,假如翻开显现提取行数

DECLARE CURSOR emp_cursor IS SELECT empno,ename,job FROM emp; v_empno emp.empno%TYPE; v_name emp.ename%TYPE; v_job emp.job%TYPE;BEGIN OPEN emp_cursor; LOOP  FETCH emp_cursor INTO v_empno,v_name,v_job;  EXIT WHEN emp_cursor%NOTFOUND; END LOOP; IF emp_cursor%ISOPEN THEN DBMS_OUTPUT.PUT_LINE('游标已翻开'); DBMS_OUTPUT.PUT_LINE('读取了'||emp_cursor%ROWCOUNT||'行'); ELSE DBMS_OUTPUT.PUT_LINE('游标没有翻开'); END IF;  CLOSE emp_cursor;END;

经过%ISOPEN特点判别游标是否翻开,%ROWCOUNT判别获取行数。

2、隐式游标:由体系界说并为它创立作业区域,而且隐式的界说翻开提取封闭,隐式游标的游标名便是'SQL',特点和显现游标相同,首要用于对单行select句子或dml操作进行处理。Example:又用户输入职工号修正职工薪酬如成功则打印输出成功标志。

为了尽量不改动原表,创立新表emp_new和原表数据相同:

CREATE TABLE emp_newASSELECT * FROM emp;
BEGIN UPDATE emp_new SET sal = sal+500 WHERE empno=&empno; IF SQL%FOUND THEN DBMS_OUTPUT.PUT_LINE('成功修正'); COMMIT; ELSE DBMS_OUTPUT.PUT_LINE('修正失利'); ROLLBACK; END IF;END;

这儿留意增删改今后要对做的操作进行commit提交,假如操作失利则rollback回滚方才的操作。

3、参数游标:

在界说游标时参加参数的游标,能够合作游标for循环快速找到需求的数据。这儿先讲一下游标for循环

A、游标FOR循环:

隐含的履行了翻开提取封闭数据,精简许多。Expression:

FOR table_record IN table_cursor LOOP

  STATEMENT;

END LOOP;

Example:运用游标For循环打印输出职工信息:

DECLARECURSOR 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:输入部门号打印职工信息:

DECLARECURSOR 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_newASSELECT * FROM emp;
DECLARECURSOR 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游标解析结束,总而言之,游标仅仅作为咱们从数据库中提取出来的一部分数据,咱们针对这个成果集做一系列的操作。

总结

以上便是这篇文章的悉数内容了,期望本文的内容对咱们的学习或许作业具有必定的参阅学习价值,假如有疑问咱们能够留言沟通,谢谢咱们对明升m88.com的支撑。

您或许感爱好的文章:

  • Oracle 游标运用总结
  • Oracle显现游标的运用及游标for循环
  • Oracle存储进程回来游标实例详解
  • oracle 在一个存储进程中调用另一个回来游标的存储进程
  • Oracle中游标Cursor根本用法详解
  • 在Oracle PL/SQL中游标声明中表名动态改变的办法
  • Oracle存储进程游标用法剖析
  • Oracle呈现超出翻开游标最大数的解决办法
  • oracle 声明游标(不具备字段)规矩使用
  • 详解Oracle隐式游标和显式游标

相关文章

    无相关信息

微信扫一扫

明升m88.com微信大众渠道