游标是一个指针,它指向一块SQL区域,该区域用于存储处理过来的SELECT或者其他的DML操作返回的数据。由PLSQL创建并管理的游标成为隐式游标,用户创建并管理的成为显示游标。游标可以看做是指向记录集合的指针,他可以在集合记录中移动以访问每条记录的功能。

显示游标的使用:

创建游标

CURSOR cursor_name IS sql_statement;

游标一旦创建成功,Oracle会为其分配内存,并与定义的SQL关联起来。

打开游标

OPEN cursor_name [argument,。。。];

获取数据

FETCH cusrsor_name INTO variblep[,varible];

①执行上述指令时,只能获取记录集合中的一行记录,将这行记录放入随后的变量中,这些变量的数据类型必须与记录中每列的数据类型相同。

关闭游标

CLOSE cursor_name

游标的属性

%ISOPEN:判断游标是否打开

%FOUND:游标是否发现数据

%NOTFOUND:游标没有发现数据

%ROWCOUNT:游标可以遍历的记录数量

访问游标属性的方法: cursor_name.attribute_name

游标使用实例:

DECLARE

var1 VARCHAR2(20);--变量的声明

var2 VARCHAR2(20);

CURSOR cursor_name IS SELECT * FROM table_name;--创建游标

BEGIN

OPEN cursor_name; --打开游标

LOOP  --循环

FETCH cursor_name INTO var1,var2; --遍历游标 ***

dbms_output.put_line('bianlaing'||var1||'=='||var2);

EXIT WHEN cursor_name%NOTFOUND; --判断是否有数据

END LOOP; --循环结束

CLOSE cursor_name; --关闭游标

END;

①的解释var1 和 var2 必须和table_name表遍历结果集的数据类型分别对应

隐式游标的使用:

隐式游标是没有声明的游标,没有显示的创建游标只是在PLSQL代码块中执行SQL语句,这些语句就是隐式游标。

DECLARE

names VARCHAR2(10);

BEGIN

SELECT count(first_name) INTO names FROM emp;

dbms_output.put_line('count:='||names);

(这就是隐式游标)

END;

在用户每次运行select或者DML操作时,PLSQL会自动创建一个隐式游标,隐式游标无法控制,一旦涉及的SQL语句结束,隐式游标也会自动关闭。想要获得游标信息可以通过隐式游标的属性。

隐式游标的属性

SQL%ISOPEN:判断游标是否打开

SQL%FOUND:游标是否发现数据

SQL%NOTFOUND:游标没有发现数据

(该属性对于PLSQL的select into 语句没有用处,PLSQL认为其是一个非法操作,因为如果发生select into没有数据返回的情况,将会触发一个预定义异常NO_DATA_FOUND)

SQL%ROWCOUNT:用于发现游标中涉及的返回结果行的数量。

FOR游标

使用for游标不需要使用变量,也不需要显示的打开和关闭游标,这些是自动执行的,也不需要去fetch游标。

DECLARE

CURSOR cursor_nameIS SELECT * FROM table_name;--声明游标

BEGIN

FOR cursor_record IN cursor_name -for游标的使用

LOOP

dbms_output.put_line('变量'||cursor_record .chars||'=='||cursor_record .num);

END LOOP;

END;

For 游标语法中cursor_record 为一条记录的集合,他自动定义一个%ROWTYPE类型的变量,%ROWTYPE变量包含对应于记录中的多列变量,通过这个变量可以依次访问记录中的每个列值

游标表达式

Select deptno,dname,cursor(select empno,ename,sal from emp where deptno=d.deptno)from dept d;

游标变量/动态游标

像游标cursor一样,游标变量ref cursor指向指定查询结果集当前行。游标变量显得更加灵活因为其声明并不绑定指定查询。

其主要运用于PLSQL函数或存储过程以及其他编程语言Java等程序之间作为参数传递。

不像游标的一点,游标变量没有参数。

游标变量具有以下属性:

(%FOUND, %NOTFOUND, %ISOPEN, and %ROWCOUNT)

1、声明格式:

DECLARE

TYPE ref_cursor_name IS REF CURSOR RETURN tablename%ROWTYPE;

游标变量又分为强类型strong(with a return type)和弱类型(with no return type):

TYPE empcurtyp IS REF CURSOR RETURN employees%ROWTYPE; -- 强类型

TYPE genericcurtyp IS REF CURSOR; -- 弱类型

my_cursor SYS_REFCURSOR; -- 使用预定义游标变量sys_refcursor

例子:

TYPE deptcurtyp IS REF CURSOR RETURN departments%ROWTYPE;

dept_cv deptcurtyp; -- 声明游标变量

或是返回record类型:

DECLARE

TYPE EmpRecTyp IS RECORD (

employee_id NUMBER,

last_name VARCHAR2(25),

salary NUMBER(8,2));

--声明record

TYPE EmpCurTyp IS REF CURSOR RETURN EmpRecTyp;

emp_cv EmpCurTyp;

使用游标变量最为参数传递

DECLARE

TYPE empcurtyp IS REF CURSOR RETURN employees%ROWTYPE;

emp empcurtyp;

PROCEDURE process_emp_cv (emp_cv IN empcurtyp) IS  --参数类型为游标类型

person employees%ROWTYPE;

OPEN emp FOR SELECT * FROM employees WHERE ROWNUM

process_emp_cv(emp);

CLOSE emp;

在包中声明游标变量

CREATE PACKAGE emp_data AS

TYPE empcurtyp IS REF CURSOR RETURN employees%ROWTYPE;

PROCEDURE open_emp_cv (emp_cv IN OUT empcurtyp);

END emp_data;

提取游标记录到集合类型

DECLARE

TYPE empcurtyp IS REF CURSOR;--声明动态游标

TYPE namelist IS TABLE OF employees.last_name%TYPE; --namelist集合

TYPE sallist IS TABLE OF employees.salary%TYPE;--sallist集合

emp_cv empcurtyp;

names namelist;--lsit -name

sals sallist;--list -sal

BEGIN

OPEN emp_cv FOR SELECT last_name, salary FROM employees

WHERE job_id = 'SA_REP';

FETCH emp_cv BULK COLLECT INTO names, sals; --BULK COLLECT INTO 的使用

CLOSE emp_cv;

FOR i IN names.FIRST .. names.LAST

LOOP

DBMS_OUTPUT.PUT_LINE('Name = ' || names(i) || ', salary = ' || sals(i));

END LOOP;

END;

通过bulk collect减少loop处理的开销

采用bulk collect可以将查询结果一次性地加载到collections中。

而不是通过cursor一条一条地处理。

可以在select into,fetch into,returning into语句使用bulk collect。

注意在使用bulk collect时,所有的into变量都必须是collections.

游标变量的使用限制

1、不能再包说明中声明游标变量;

2、不能用“=”运算符比较游标变量相等性、不等性及是否为空;

3、不能存储于表列中;

4、不能将游标变量存在于关联数组、嵌套表或数组;

5、游标和游标变量之前是不可互操作的!

PLSQL游标

静态游标:结果集已经确实(静态定义)的游标.分为隐式和显式游标 隐式游标:所有DML语句为隐式游标,通过隐式游标属性可以获取SQL语句信息: 显式游标:用户显式声明的游标,即指定结果集.当查询返回结果 ...

SQL记录-PLSQL游标

PL/SQL游标 Oracle会创建一个存储区域,被称为上下文区域,用于处理SQL语句,其中包含需要处理的语句,例如所有的信息,行数处理,等等. 游标是指向这一上下文的区域. PL/SQL通过控制光标 ...

Oracle PLSQL游标、游标变量的使用

参考文章:https://www.cnblogs.com/huyong/archive/2011/05/04/2036377.html 在 PL/SQL 程序中,对于处理多行记录的事务经常使用游标来实 ...

PLSQL开发笔记和小结(转载)

*****************************************   PLSQL基本结构 ***************************************** 基本数据 ...

Oracle之PLSQL总结

基本数据类型变量 1. 基本数据类型     Number 数字型     Int 整数型     Pls_integer 整数型,产生溢出时出现错误 Binary_integer 整数型,表示带符号 ...

PLSQL开发笔记和小结

*****************************************  PLSQL基本结构*****************************************基本数据类型变 ...

PLSQL学习教程(全)

基于ORACLE9i+PL/SQLDeveloper7.1.4) 课程 一 PL/SQL 基本查询与排序 本课重点: 1.写SELECT语句进行数据库查询 2.进行数学运算 3.处理空值 4.使用别名 ...

plsql oracle 使用教程

课程 一 PL/SQL 基本查询与排序 本课重点: 1.写SELECT语句进行数据库查询 2.进行数学运算 3.处理空值 4.使用别名ALIASES 5.连接列 6.在SQL PLUS中编辑缓冲,修改 ...

Oracle存储过程、游标、函数

SQL99是什么 (1)是操作所有关系型数据库的规则 (2)是第四代语言 (3)是一种结构化查询语言 (4)只需发出合法合理的命令,就有对应的结果显示 SQL的特点 (1)交互性强,非过程化 (2)数 ...

随机推荐

1Z0-053 争议题目解析175

1Z0-053 争议题目解析175 考试科目:1Z0-053 题库版本:V13.02 题库中原题为: 175.You are peer reviewing a fellow DBAs backup p ...

1.SQLAlchemy文档-简介(中文版)

Python的SQL工具包和对象关系映射器     SQLAlchemy的是Python的SQL工具包和对象关系映射器,让应用程序开发人员可以使用上SQL的强大功能和灵活性.     它提供了一套完整 ...

ERP_基于Oracle SOA的企业服务总线整合

2015-01-01 Created By BaoXinjian

frameset iframe用来分页

frameset用来分大的框架 iframe用来在frame分框架之后,内嵌分割.

Linux查看用户所属用户组

1.查看当前用户所属用户组 [oracle@serverhl ~]$ groups oinstall dba 2.查看, 和

C# 一些不注意知识点:命名空间,等级,class等等

C# 命名空间表示域,控制着域内的对象. 命名空间是第一等级,class,delegate,enum,interface,struct是第二等级: 方法,属性,字段,索引,事件,常量,构造函数,终结器 ...

java项目(学习和研究)

java项目就是研究,不断的对项目进行迭代,把产品做的越来越好,就是research. 自己想着做一个java项目把,可以类似牛客网,想好自己的预期产品,在设计的过程中可以不断改进和扩展,在做这个项目 ...

为你的机器学习模型创建API服务

1. 什么是API 当调包侠们训练好一个模型后,下一步要做的就是与业务开发组同学们进行代码对接,以便这些‘AI大脑’们可以顺利的被使用.然而往往要面临不同编程语言的挑战,例如很常见的是调包侠们用Pyt ...

css 禁止录入中文

1.情景展示 如何禁止输入框,输入中文字符? 2.解决方案 IE浏览器,可以使用ime-mode来实现 UpdateTime--2016年12月15日19:52:16 /*屏蔽输入法,可以用来禁止 ...

plsql存过声明游标_PLSQL游标使用相关推荐

  1. plsql存过声明游标_plsql--游标用法

    1.游标概念 在 PL/SQL 块中执行 SELECT.INSERT.DELETE 和 UPDATE 语句时,ORACLE 会在内存中为其分配上下文区(Context Area),即缓冲区.游标是指向 ...

  2. plsql存过声明游标_plsql编程学习之游标一

    oralce plsql编程的游标 游标分类 1显示游标 2隐式游标 隐式游标,oracle自动管理,不用声明,打开和关闭,ORACLE自动处理,使用隐式游标%FOUND时,需要加上 SQL%FOUN ...

  3. plsql存过声明游标_plsql 存储过程游标

    PLSQL PL/SQL块 PL/SQL块是在SQL语言之上发展起来的一种应用,可以集中的处理各种复杂的SQL操作. 组成: DECLARE: 声明部分 BEGIN 编写趁许的主题 EXCEPTION ...

  4. 游标声明 oracle,Oracle游标声明

    这篇文章中将演示如何在Oracle / PLSQL中声明游标的语法和示例. 游标是在PLSQL代码的声明部分中定义的SELECT语句.下面来看看三种不同的语法来声明游标. 1. 没有参数的游标(最简单 ...

  5. oracle数据库定义游标,Oracle游标声明

    这篇文章中将演示如何在Oracle / PLSQL中声明游标的语法和示例. 游标是在PLSQL代码的声明部分中定义的SELECT语句.下面来看看三种不同的语法来声明游标. 1. 没有参数的游标(最简单 ...

  6. mysql 游标 navigate_MySQL游标的概念介绍和游标的使用讲解

    一.MySQL游标的概念 1.游标介绍 MySQL的游标(cursor)是一个重要的概念,通过查找资料与自己的理解,主要得出以下几点关于自己的理解. 有数据缓冲的思想:游标的设计是一种数据缓冲区的思想 ...

  7. oracle中的cursor属性有哪些,Oracle学习11:游标(cursor)--显式游标隐式游标、游标四个属性、循环遍历...

    1.概述 上文PLSQL学习中提到的知识,可以发现,基本都可以通过Java等语言实现,而为了实现程序的可移植性,实际开发工作中我们也是如此做的. 那么PLSQL的重点是什么呢?接下来我们来介绍游标cu ...

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

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

  9. 什么是mysql的游标_MySQL游标概念是什么 MySQL游标概念与用法介绍

    本篇文章小编给大家分享一下MySQL游标概念与用法介绍,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看. 1.游标的概念(Cursor) 一条sql,对应N条资源,取出资源的接 ...

  10. oracle 如何创建游标,Oracle--plsql游标创建和使用

    Oracle--plsql游标创建和使用 为什么要游标: 先看这个: DECLARE v_empno emp.empno%type; v_ename emp.ename%type; BEGIN SEL ...

最新文章

  1. SOA 的基本概念及设计原则浅议
  2. RocketMQ控制台安装教程
  3. MAT之GRNN/PNN:基于GRNN、PNN两神经网络实现并比较鸢尾花(iris数据集)种类识别正确率、各个模型运行时间对比
  4. 计算机自动启动无法开机,开机自启动被关闭,无法保护计算机安全,这是为啥。怎么办?...
  5. python有什么简单项目_python有什么简单项目适合初学者?
  6. Spring.Web.Mvc 注入(控制器属性注入)
  7. c语言中主函数创建链表,主函数怎么调用函数(数据结构,创建链表)
  8. md0 mysql_mysql 数据合并
  9. SAP Spartacus List Component 里定义的待显示 Popover 内容,如何传递到 Popover Component 里的?
  10. java 不加锁_在java中,在高并发的时候,不加锁的时候。
  11. pdf转HTML出现乱码,PDF转Word出现乱码解决方法
  12. 华为数据之道(5):华为数字化转型的目标、蓝图和愿景
  13. 10种自动音乐播放器代码
  14. 使用pdfobject.js实现在线浏览PDF
  15. 自制USB充电线、数据线、工程线、OTG线的方法
  16. Nomad 多job/group/task调度测试
  17. 分布式、微服务(一)——理论简述
  18. 福州大学计算机考研好考,福州大学数学考研好不好考,考研考哪些?福大数学考研考情分析。...
  19. 后台产品的数据可视化图表产品设计
  20. 运营-1.活跃用户数:

热门文章

  1. 将已经汉化了的Protel 99 SE整回英文原版
  2. java实现远程桌面监控
  3. 使用Setup Factory如何制作程序安装包
  4. 居家短期任务赚钱好不好做容易学习吗?
  5. 永中集成Office要敢于继续挑战微软Office
  6. xmpp 即时通讯
  7. COM组件的编写与注册
  8. 智能交通灯(根据车流量检测)
  9. JS实现文字转语音播放
  10. 在苹果笔记本如何使用python_苹果电脑系统如何运行python工具介绍