一、简介

定义

  • 实质上是数据集,类似数组一样,把查询的数据集存储在内存当中。
  • 使用时可以通过游标指向其中一条记录,也可以通过循环游标达到循环数据集的目的。

游标的种类

显式游标:

  • 使用之前必须得先声明定义,一般是对查询语句的结果进行定义游标。   
  • 可以通过游标循环获取结果集内的记录,也可以根据业务需求跳出循环结束游标的获取。
  • 循环完成后,可以通过关闭游标,结果集就不能再获取了。全部操作完全由开发者自己编写完成,自己控制。

隐式游标:

指的是PL/SQL自己管理的游标,开发者不能自己控制操作,只能获得它的属性信息。

二、显式游标

  显式游标在实际开发中经常使用到,可以丰富PL/SQL的开发程序的编写,实现一些循环类的复杂业务。游标的使用步骤如下:

--1.声明游标:    
  声明游标指的是给游标命名并给游标关联一个查询结果集
cursor 游标名
is 查询语句 --2.打开游标:
  初始化游标指针
  PS
:游标一旦打开后,游标对应的结果集就是静态不会再变了,不管查询的表的基础数据发生了变化。
open 游标名; --3.读取游标中数据:
  通过fetch into语句完成,把当前游标指针指向的数据行读取到对应的变量中(声明的record变量)。
  PS
:游标读取一般和循环LOOP一起使用,用于循环获取数据集中的记录。
fetch 游标名 into 声明的record变量 --4、关闭游标:
  关闭后,该游标关联的结果集就释放了,不能够再操作了
  PS
:游标使用完,一定要关闭游标释放资源。
close 游标名;

显式游标的属性

我们利用显式游标的属性值来获取游标所处的状态,然后对应做相应的处理,常用的属性有四个:

  • %NOTFOUND。表示游标获取数据的时候是否有数据提取出来,没有数据返回TRUE,有数据返回false,经常被用来判断游标是否全部循环完毕。
  • %FOUND。正好和%NOTFOUND相反,当游标提取数据值时有值,返回TRUE,否则返回FALSE。
  • %ISOPEN。用来判断游标是否打开。
  • %ROWCOUNT。表示当前游标FETCH INTO获取了多少行的记录值,用来做计数用的。

  例子:创建一个游标循环打印学生信息表中学生基本信息,代码如下:

--定义游标
declare cursor cur_xsjbxx
is select * from stuinfo order by stuid;
--定义记录变量 rowtype:用于接受一行数据
ls_curinfo cur_xsjbxx%rowtype;
begin
--打开游标
open cur_xsjbxx;
--循环
loop
--获取记录值并写入计入变量
fetch cur_xsjbxx into ls_curinfo;
--当没有数据时不再获取(%NOTFOUND用来判断游标是否全部循环完毕。)
exit when cur_xsjbxx%notfound;
--PL/sql中输出信息(相当与java中的System.out.println())
dbms_output.put_line('学号:' || ls_curinfo.stuid || ',姓名:' || ls_curinfo.stuname);
end loop;
--关闭游标
close cur_xsjbxx;
end;

三、隐式游标

  • 隐式游标虽然不能像显式游标一样具有操作性,但是在实际开发过程当中还是经常使用到它的属性值。
  • 隐式游标主要是用在select语句或一些dml操作语句时,PL/SQL程序会自动打开隐式游标,这个隐式游标是不受开发者控制的。
  • oracle隐式游标没有像显式游标一样声明游标名,而是直接采用“SQL”或“sql”作为隐式游标的名称。
  • 显式游标表示的属性值都是对结果集行数的一些判断,而隐式游标对应的就是DML语句影响的行数。
--隐式游标
declare
--只定义记录变量,没有声明游标(如果一个表有较多的列,使用%rowtype来定义一个表示表中一行记录的变量)
ls_xsjbxx stuinfo%rowtype;
begin
--查询学生信息(select * into把整个表数据设置进定义的记录变量中,用变量来实现游标功能)
select * into ls_xsjbxx from stuinfo t where t.stuid = 'SC201801001';
if sql%found then
dbms_output.put_line('学号:' || ls_xsjbxx.stuid || ',姓名:' || ls_xsjbxx.stuname);
end if; --查询学生信息(不存在的学生)
select * into ls_xsjbxx from stuinfo t where t.stuid = 'SC201901001';
if sql%found then
dbms_output.put_line('学号:' || ls_xsjbxx.stuid || ',姓名:' || ls_xsjbxx.stuname);
end if;
exception
when no_data_found then
dbms_output.put_line('该学生SC201901001不存在');
end;

Oracle学习(七)游标的更多相关文章

  1. (七)Oracle学习笔记—— 游标

    1.游标简介 游标用来处理从数据库中检索的多行记录(使用SELECT语句).利用游标,程序可以逐个地处理和遍历一次检索返回的整个记录集. 为了处理SQL语句,Oracle将在内存中分配一个区域,这就是 ...

  2. oracle学习 九 游标的使用(持续更)

    为什么要使用? 笔者查阅了一些资料之后得到的结论是, 关系型数据库是面向集合的,而游标是面向行的,游标可对取出来的集合(结果集)中每一行进行相同或不同的操作,还提供对基于游标位置而对表中数据进行删除或 ...

  3. oracle学习 七 拼接变量+日期函数(持续更)

    select count(KEYCODE) from STHSGDOC.ZJSJJL where ysrq=to_date(to_char(sysdate,'yyyy')||'/1','yyyy/MM ...

  4. Oracle学习(七):集合运算

    1.知识点:能够对比以下的录屏进行阅读 SQL> -- 查询10和20号部门的员工的3种方法 SQL> --1. select * from emp where deptno in (10 ...

  5. 7.oracle学习门户系列七---网络管理和配置

    oracle学习门户系列七 网络管理和配置 们学习了模式和用户.包含模式定义以及模式的作用. 这篇我么来看下ORACLE数据库中的网络管理和配置.只是这篇好像和上篇没有继承啊.这怎么看? Ok,事实上 ...

  6. oracle学习--循环语句

    oracle学习--循环语句  loop循环: create or replace procedure pro_test_loop is i number; begin i:=0; loop i:=i ...

  7. Oracle 学习(scott方案)

      Oracle学习中,重点是sql语句的学习,而所有的sql语句都要在scott用户下完成. 熟悉这个用户下的四张表,是必要的. 查看所有表名: SELECT * FROM tab; 查看每张表的结 ...

  8. (转)MyBatis框架的学习(七)——MyBatis逆向工程自动生成代码

    http://blog.csdn.net/yerenyuan_pku/article/details/71909325 什么是逆向工程 MyBatis的一个主要的特点就是需要程序员自己编写sql,那么 ...

  9. Oracle学习笔记三 SQL命令

    SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)  

随机推荐

  1. shazidouhuiapp

    在选择了软件工程专业之后,指导教师也让我们参加到了学长学姐的作业之中来,使用学长学姐们的软件并写出自己的使用评价以及自己的一些小评价. 我这次体验的是第三组的学长学姐们的软件,他们的队名叫天公疼憨仔, ...

  2. flutter 设置状态栏的背景与颜色

    flutter 设置状态栏的背景与颜色 导包 import 'dart:io'; import 'package:flutter/services.dart'; 在main()函数中添加以下函数, v ...

  3. 关于对MyBatis.net框架的学习笔记( MyBatis.net是一款灵活性极大,sql由开发者自行在xml中编写, 轻量的ORM映射框架). 同时避免了sql硬编码到代码中不易维护的问题...

    对于为什么要用ORM,为什么又要选择MyBatis.net,这个问题希望读者自行查找资料.这里直接贴出相关的调试笔记. 步骤1)下载与引用. http://code.google.com/p/myba ...

  4. MySQL锁这块石头似乎没有我想的那么重

    前言 前言为本人写这篇文章的牢骚,建议跳过不看.   之前好几次都想好好的学习MySQL中的锁,但是找了几篇文章,看了一些锁的类型有那么多种,一时间也没看懂是什么意思,于是跟自己说先放松下自己,便从书 ...

  5. [] !== [] is true

    这周工作看见一个小伙伴给我私信发了这样的一个问题,我深剖了一下,希望大家能早点脱掉这个坑. Question: 如果定义了一个空数组,在开发过程中经常会做这样的一个判断,就是这个数组里发生变化不再是空 ...

  6. Stack (30)(模拟栈,输出中间数用set)

    Stack is one of the most fundamental data structures, which is based on the principle of Last In Fir ...

  7. 如何使用Grep命令查找多个字符串

    如何使用Grep 命令查找多个字符串 大家好,我是良许! 今天向大家介绍一个非常有用的技巧,那就是使用 grep 命令查找多个字符串. 简单介绍一下,grep 命令可以理解为是一个功能强大的命令行工具 ...

  8. Python 利用三个简易模块熟悉前后端交互流程

    准备工作 在学习Django之前,先动手撸一个简单的WEB框架来熟悉一下前后端交互的整体流程 本次用到的模块: 1.wsgiref,这是一个Python自带的模块,用于构建路由与视图 2.pymysq ...

  9. Jemter响应数据乱码

    问题分析: 请求响应数据出现中文时,通过查看jemter的察看结果树中的响应数据信息,出现乱码.经过查看jemter的配置文件jmeter.properties发现其默认字符集编码为ISO-8859- ...

  10. 当this碰到return会发生什么

    当this碰到return时 function fn(params) { this.user = 'fzy' return {} } var a = new fn console.log(a.user ...