Oracle游标
概念:内存中的一块区域,存放select结果
游标用来处理从数据库中检索的多行记录(使用SELECT语句)。利用游标,程序可以逐个地处理和遍历一次检索返回的整个记录集。
一、显示游标(处理返回多行数据的SELECT 语句)

  • 声明游标;CURSOR cursor_name IS select_statement
  • 为查询打开游标;OPEN cursor_name
  • 取得结果放入PL/SQL变量中;
 FETCH cursor_name INTO list_of_variables;
FETCH cursor_name INTO PL/SQL_record;
  • 关闭游标CLOSE cursor_name

二、隐式游标(所有的隐式游标都被假设为只返回一条记录。)
使用隐式游标时,用户无需进行声明、打开及关闭。PL/SQL隐含地打开、处理,然后关掉游标。

 SELECT studentNo,studentName
INTO curStudentNo,curStudentName
FROM StudentRecord
WHERE name=’gg’;

上述游标自动打开,并把相关值赋给对应变量,然后关闭。执行完后,PL/SQL变量curStudentNo,curStudentName中已经有了值
特点:

  • 隐式游标是单条sql语句所产生的结果集合
  • 多条sql语句,隐式游标指向最后一条sql语句的结果
  • 主要用在update和delete上

三、实际操作游标
1、for循环游标
(1)定义游标
(2)定义游标变量
(3)使用for循环来使用这个游标
四、游标的四个属性

  • %notfound fetch是否提到数据 没有true 提到false
  • %found fetch是否提到数据 有true 没提到false
  • %rowcount 已经取出的记录的条数
  • %isopen 布尔值 游标是否打开

小细节:
1、区别
%TYPE 声明一个列类型
%ROWTYPE 声明一个行类型
好处:更改了列、行的长度或者数据类型,会自动进行调整
2、游标和游标变量区别
oracle游标只是数据库中一个命名的工作区,当游标声明后,就与一个固定的sql关联
游标变量可以与不同的SQL语句关联,在运行时取不同的sql语句,指向不同的工作区
3、oracle中的弱游标有返回值,而且必须是%rowtype类型,而强游标无返回值
4、exit when语句一定要紧跟在fetch之后。必避免多余的数据处理

五、实际代码

简单的游标查询

 --声明游标并且赋值(通过sql语句)
declare
cursor retail is select * from retailretnotice;
--声明游标变量
sheet_cur retailretnotice%rowtype;
--开始for循环
begin
--开始循环
open retail;
--开启游标
loop
--开启循环
exit when retail%notfound;
--当游标没有提到数据,退出
fetch retail into sheet_cur;
--循环游标(使用fetch游标,必须明确的打开和关闭)
dbms_output.put_line(sheet_cur.sheetid);
--输出数据
end loop;
--结束循环
--关闭游标
close retail;
end;

在Oracle中,有更简洁的方法

 begin
for R in (select * from retailretnotice)
loop
dbms_output.put_line(R.sheetid);
end loop;
end;

for循环游标
1、声明游标(并且赋值)
2、声明游标变量
3、进行for循环输出

Oracle中的游标的更多相关文章

  1. oracle 中的游标

    oracle 中的游标 通俗易懂的sql代码直接上! --简单的游标使用滴呀 --使用FOR OBJ IN OBJS LOOP ......END LOOP; DECLARE CURSOR C_JOB ...

  2. Oracle中使用游标转换数据表中指定字段内容格式(拼音转数字)

    应用场景:将数据表TB_USER中字段NNDP的内容中为[sannanyinv]转换为[3男1女] 主要脚本:一个游标脚本+分割字符串函数+拼音转数字脚本 操作步骤如下: 1.创建类型 create ...

  3. Oracle中使用游标获取指定数据表的所有字段名对应的字符串

    操作步骤:打开PLSQL Developer后,直接执行下面的语句就可以出来 --Oracle中使用游标获取指定数据表的所有字段名对应的字符串 declare mytablename VARCHAR( ...

  4. Oracle中的游标(转)

    Oracle中的游标有两种:显式游标.隐式游标.显示游标是用cursor...is命令定义的游标,它可以对查询语句(select)返回的多条记录进行处理,而隐式游标是在执行插入 (insert).删除 ...

  5. java实现调用ORACLE中的游标和包

    今天把oracle中的包和游标学习了下,不废话,网上的的有些代码是错误的,抄来抄去,就自己实践了下,做个记录.直接上图,上代码 通过plsql创建自己的的包,包分为包头和包体. 1.包头如下: CRE ...

  6. Oracle 中的游标(用Javase中Iterator 类比之)

    当使用 pl/sql 查询 Oracle 数据库时,有时我们想输出多条记录的数据.:select * from scott.emp; 这时,我们一定会想利用循环来输出.但是,在pl/sql 中是没有数 ...

  7. Oracle中的游标的原理和使用详解

    游标的简介 逐行处理查询结果,以编程的方式访问数据. 游标的类型: 1,隐式游标:在 PL/SQL 程序中执行DML SQL 语句时自动创建隐式游标,名字固定叫sql. 2,显式游标:显式游标用于处理 ...

  8. 【转】oracle中的游标的原理和使用详解

    游标 游标的简介: 逐行处理查询结果,以编程的方式访问数据 游标的类型: 1,隐式游标:在 PL/SQL 程序中执行DML SQL 语句时自动创建隐式游标,名字固定叫sql. 2,显式游标:显式游标用 ...

  9. ORACLE中的游标Cursor总结

    游标(Cursor):用来查询数据库,获取记录集合(结果集)的指针,可以让开发者一次访问一行结果集,在每条结果集上作操作. 游标可分为: 1.       静态游标:分为显式(explicit)游标和 ...

随机推荐

  1. AtCoder Regular Contest 069 D

    D - Menagerie Time limit : 2sec / Memory limit : 256MB Score : 500 points Problem Statement Snuke, w ...

  2. bzoj 3295: [Cqoi2011]动态逆序对(树套树 or CDQ分治)

    Description 对于序列A,它的逆序对数定义为满足i<j,且Ai>Aj的数对(i,j)的个数.给1到n的一个排列,按照某种顺序依次删除m个元素,你的任务是在每次删除一个元素之前统计 ...

  3. [bzoj1301] [LLH邀请赛]参观路线

    本题同bzoj1098 用个并查集,把连续的被访问过的点并起来..这样就不会尝试已经走过的点了. #include<cstdio> #include<iostream> #in ...

  4. Codeforces__Raising Bacteria

    题目传送门:Raising Bacteria //问题描述:一个盒子里面放一个细菌在一天可以增生两个细菌. 现在已知盒子里面细菌的个数,问你最初放多少个细菌可以增生盒子里面的细菌数量 //输入:盒子中 ...

  5. 最新版Sublime Text Build 3156 x64 的下载 + 注册码 + Install Package Control + 汉化教程

    一.Sublime Text  下载 神器 Sublime Text 最近开始更新到开发版本 Build 3156,本身英语不是太6,汉化党自然各种百度汉化教程,网上不是一堆绿色汉化包,就是让你下载汉 ...

  6. java中static关键字的继承问题

    结论:java中静态属性和静态方法可以被继承,但是没有被重写(overwrite)而是被隐藏. 原因: 1). 静态方法和属性是属于类的,调用的时候直接通过类名.方法名完成对,不需要继承机制及可以调用 ...

  7. 十二个 ASP.NET Core 例子——配置操作

    目录: 简单配置(利用configration 键值读取) 使用选项和配置对象(自定义类绑定配置文件实现读取) IOptionsSnapshot(配置文件更改时也变化) 内存数据放到配置对象中 实体框 ...

  8. windows 防火墙拦截nginx的问题

    今天在azure vm上安装了nginx并配置了代理设置,但域名访问始终无法中转,一开始怀疑是nginx的服务没起来,但在本地访问localhost看下如下界面,证明服务是没问题的. 本地访问没问题, ...

  9. console.log 用法

    转自http://www.cnblogs.com/ctriphire/p/4116207.html 大家都有用过各种类型的浏览器,每种浏览器都有自己的特色,本人拙见,在我用过的浏览器当中,我是最喜欢C ...

  10. 详解javascript中的闭包

    全局变量与局部变量 在说闭包之前先说明全局变量与局部变量 全局变量:变量声明时如果不使用 var 关键字,那么它就是一个全局变量,即便它在函数内定义. 局部变量:使用var关键字定义 全局变量/局部变 ...