什么是游标?

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

②关系数据库中的操作是在完整的行集合上执行的。

由 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_new

AS

SELECT * 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循环打印输出员工信息:

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游标解析完毕,总而言之,游标只是作为我们从数据库中提取出来的一部分数据,我们针对这个结果集做一系列的操作。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

oracle利用游标添加数据库,Oracle游标的使用实例详解相关推荐

  1. oracle利用游标添加数据库,Oracle数据库游标的类型及使用实例全解

    游标是SQL的一个内存工作区,由系统或用户以变量的形式定义.游标的作用就是用于临时存储从数据库中提取的数据块.Oracle数据库的Cursor类型包含三种: 静态游标:分为显式(explicit)游标 ...

  2. mysql添加新的实例_MySQL中添加新用户权限的实例详解

    有2个不同的方法增加用户:通过使用GRANT语句或通过直接操作MySQL授权表.比较好的方法是使用GRANT语句,因为他们是更简明并且好像错误少些. 下面的例子显示出如何使用MySQL客户安装新用户. ...

  3. oracle 记录给游标,Oracle游标 CURSOR实例详解

    一.游标概述: 游标(cursor)是数据库系统在内存中开设的一个数据缓冲区,存放SQL语句的执行结果. 每个游标都有一个名字,用户可以用SQL语句逐一从游标中获取记录,并赋给变量做进一步处理. 作用 ...

  4. java metadata 使用_java 查询oracle数据库所有表DatabaseMetaData的用法(详解)

    一 . 得到这个对象的实例 Connection con ; con = DriverManager.getConnection(url,userName,password); DatabaseMet ...

  5. 视频教程-Oracle数据库从入门到实用教程详解-Oracle

    Oracle数据库从入门到实用教程详解 全栈工程师,2010年从事软件开发以及软件教育培训工作,至今将近十余年,在项目的开发,设计,到管理上积累了丰富的实战经验,教学风格上通俗易懂,问题解答环节一对一 ...

  6. oracle几种例外,Oracle例外用法实例详解

    本文实例讲述了Oracle例外用法.分享给大家供大家参考,具体如下: 一.例外分类 oracle将例外分为预定义例外.非预定义例外和自定义例外三种. 1).预定义例外用于处理常见的oracle错误. ...

  7. oracle大对象实例_Oracle解析复杂json的方法实例详解

    问题背景: 当前在Oracle数据库(11G之前的版本)解析json没有可以直接使用的系统方法,网上流传的PLSQL脚本大多也只可以解析结构较单一的json串,对于结构复杂的json串还无法解析.如此 ...

  8. oracle out参数查询,Oracle的out参数实例详解

    Oracle的out参数实例详解 一 概念 1.一般来讲,存储过程和存储函数的区别在于存储函数可以有一个返回值:而存储过程没有返回值. 2.过程和函数都可以通过out指定一个或多个输出行.我们可以利用 ...

  9. oracle中表空间实例,oracle的表空间实例详解

    oracle 的表空间实例详解 查询表空间 SELECT UPPER(F.TABLESPACE_NAME) "表空间名", D.TOT_GROOTTE_MB "表空间大小 ...

最新文章

  1. 打开 谷歌浏览器exe_谷歌浏览器下载安装和插件安装步骤
  2. 静态反调试技术(1)
  3. Linux宝塔面板介绍 Centos安装宝塔面板教程
  4. javadoc源码获取
  5. 启动代码和Bootloader的区别和关系介绍
  6. 怎么判断当前的os类型,手机类型
  7. Linux系统下,MySQL以及禅道的安装/卸载
  8. 爱因斯坦:量子物理与抽象数学(广义)
  9. android升序降序按钮,创建一个按钮,将排序MYSQL查询升序和降序
  10. 《Spring2之站立会议5》
  11. bzoj3670 [Noi2014]动物园
  12. 22条你不知道的微营销干货
  13. 查计算机主板,如何查看计算机主板的型号
  14. H.266/VVC代码学习:普通量化和率失真优化量化(RDOQ)
  15. Lync 2013和Exchange 2013集成
  16. 互联网公司技术总监工作内容
  17. GTD时间管理理念和德鲁克时间管理理念的异同
  18. emp和emn是什么文件_导出EMN,EMP文件的问题
  19. 计算机科学期刊_成为数据科学家的五种科学期刊
  20. 【好文导读】人工智能和机器学习的富有启迪的文章201802

热门文章

  1. 三十六计之瞒天过海(第一计)
  2. 时间序列分析:AR(p),MA(q)
  3. Python学习——(4)字典的操作
  4. Spark商业案例与性能调优实战100课》第16课:商业案例之NBA篮球运动员大数据分析系统架构和实现思路
  5. geekbench3 android,iPhone5 Geekbench结果出炉 比iPad3快一倍险胜Android众机
  6. 图像分类性能提升方案
  7. 技术领先、“忠”于业务,用友走出多维数据库的价值之路
  8. 左程云算法笔记(四)哈希表和有序表的使用、链表
  9. [极客大挑战 2019]Secret File 1
  10. centos服务器之间copy文件夹命令,复制文件与文件夹的CentOS常用命令