Oracle学习(七)游标
一、简介
定义
- 实质上是数据集,类似数组一样,把查询的数据集存储在内存当中。
- 使用时可以通过游标指向其中一条记录,也可以通过循环游标达到循环数据集的目的。
游标的种类
显式游标:
- 使用之前必须得先声明定义,一般是对查询语句的结果进行定义游标。
- 可以通过游标循环获取结果集内的记录,也可以根据业务需求跳出循环结束游标的获取。
- 循环完成后,可以通过关闭游标,结果集就不能再获取了。全部操作完全由开发者自己编写完成,自己控制。
隐式游标:
指的是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学习(七)游标的更多相关文章
- (七)Oracle学习笔记—— 游标
1.游标简介 游标用来处理从数据库中检索的多行记录(使用SELECT语句).利用游标,程序可以逐个地处理和遍历一次检索返回的整个记录集. 为了处理SQL语句,Oracle将在内存中分配一个区域,这就是 ...
- oracle学习 九 游标的使用(持续更)
为什么要使用? 笔者查阅了一些资料之后得到的结论是, 关系型数据库是面向集合的,而游标是面向行的,游标可对取出来的集合(结果集)中每一行进行相同或不同的操作,还提供对基于游标位置而对表中数据进行删除或 ...
- oracle学习 七 拼接变量+日期函数(持续更)
select count(KEYCODE) from STHSGDOC.ZJSJJL where ysrq=to_date(to_char(sysdate,'yyyy')||'/1','yyyy/MM ...
- Oracle学习(七):集合运算
1.知识点:能够对比以下的录屏进行阅读 SQL> -- 查询10和20号部门的员工的3种方法 SQL> --1. select * from emp where deptno in (10 ...
- 7.oracle学习门户系列七---网络管理和配置
oracle学习门户系列七 网络管理和配置 们学习了模式和用户.包含模式定义以及模式的作用. 这篇我么来看下ORACLE数据库中的网络管理和配置.只是这篇好像和上篇没有继承啊.这怎么看? Ok,事实上 ...
- oracle学习--循环语句
oracle学习--循环语句 loop循环: create or replace procedure pro_test_loop is i number; begin i:=0; loop i:=i ...
- Oracle 学习(scott方案)
Oracle学习中,重点是sql语句的学习,而所有的sql语句都要在scott用户下完成. 熟悉这个用户下的四张表,是必要的. 查看所有表名: SELECT * FROM tab; 查看每张表的结 ...
- (转)MyBatis框架的学习(七)——MyBatis逆向工程自动生成代码
http://blog.csdn.net/yerenyuan_pku/article/details/71909325 什么是逆向工程 MyBatis的一个主要的特点就是需要程序员自己编写sql,那么 ...
- Oracle学习笔记三 SQL命令
SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)
随机推荐
- 如何运用excel或spss等软件统计大量纸质问卷?
在用纸质问卷进行数据收集时,总是避不开一个问题,就是如何把数据快速准确的进行统计分析.这里提供一个方法,包括以下几个步骤: 一.录入数据 二.上传数据 三.分析数据 一.录入数据 首先把纸质问卷 ...
- Win 10 蓝屏,出现DRIVER_POWER_STATE_FAILURE的解决方法
笔者个人笔记本电脑,用的是华硕的飞行堡垒FZ系列,上个月装了个Ubuntu的系统,之后换回Windows后,电脑疯狂蓝屏,错误代码只有这个DRIVER_POWER_STATE_FAILURE.一开始我 ...
- 国内几大seo高手(夫唯,王通,久久)的技术分析
http://www.wocaoseo.com/thread-146-1-1.html 目前学习seo的人越来越多了,这种技术的普及和推广也在不断的扩大,先进的好的培训机构不断涌现,很多高水平老师都在 ...
- 高可用集群之corosync+pacemaker
1.概念 在传统Linux集群种类,主要分了三类,一类是LB集群,这类集群主要作用是对用户的流量做负载均衡,让其后端每个server都能均衡的处理一部分请求:这类集群有一个特点就是前端调度器通常是单点 ...
- csp201909-2小明种苹果续
/* 定义输入N 二维数组 输出T总数 D掉落棵树 E掉落组数 定义last记录上次掉落的编号,flag=1表示两次连续掉落,不掉落归零 spec=1表示1 2都掉落了,spec=2表示只有1掉落 对 ...
- 【Android】SwipeRefreshLayout的简单使用教程。下拉刷新控件炫酷效果。
作者:程序员小冰,GitHub主页:https://github.com/QQ986945193 新浪微博:http://weibo.com/mcxiaobing 首先给大家看一下我们今天这个最终实现 ...
- Unity3d流光效果
Material中纹理的属性都有Tiling和Offset,可以利用Offset做uv动画,从而完成各种有趣的动画,比如流光效果! 流过效果即通常一条高光光在物体上划过,模拟高光移动照射物体的效果,之 ...
- Spring Cloud:Consul基础知识
一.基本概念 Consul是一套开源的分布式服务发现和配置管理系统,由HashiCorp公司用Go开发. 它提供微服务系统中的服务治理.配置中心.控制总线等功能. 服务发现:提供HTTP和DNS两种发 ...
- HashMap位运算你可知一二
前置位运算知识 我们平时在写代码过程中用的位运算操作比较少,因为我们更关注于可读性而不是性能,如果为了性能而使用较多的位运算,我想我们的同事会疯掉.但在框架里位运算却非常常见,因为框架的性能是我们关注 ...
- 18_Python常用的模块中的某个方法
1.imp模块==========>重新加载已加载过的模块方法 import imp imp.reload(mymod) # 重新加载已经加载过的mymod模块 2.ctypes模块====== ...