原文链接:http://blog.csdn.net/liujiahan629629/article/details/18014051
以前也接触过游标,但是打心里说不是太理解,通过这次学习感觉理解深刻了很多,特此总结学习一下。
一,游标是什么?
游标是一段私有的SQL工作区,也就是一段内存区域,用于暂时存放受SQL语句影响到的数据。通俗理解就是将受影响的数据暂时放到了一个内存区域的虚表中,而这个虚表就是游标。
二,作用是什么?
1,大家都知道数据库中的事物可以回滚,而游标在其中起着非常重要的作用,由于对数据库的操作我们会暂时放在游标中,只要不提交,我们就可以根据游标中内容进行回滚,在一定意义有利于数据库的安全。
2,另外,在Oracle中PL/SQL只能返回单行数据,而游标弥补了这个不足。相当于ADO.NET中的Data table吧。
三,类型:
1,隐式游标:增删改等操作Oracle都会自动创建游标,暂时保存操作结果,也就是能够回滚的操作都会引发游标的创建。
2,显示游标:由开发人员通过程序显式控制,用于从表中取出多行数据,并将多行数据一行一行的单独进行处理.
四,属性:
属性
注释
%rowcount
受SQL影响的行数
%found
Boolean值,是否还有数据
%notfound
Boolean值,是否已无数据
%isopen
游标是否打开
当然如果我们想获得隐式游标的属性,通过%前边加上SQL即可得到。例如SQL%rowcount.
五,游标简单认识了,我们来看看游标的具体使用:
1,先看一下简单的使用游标四步骤:
步骤
关键词
说明
1
在DECLARE中cursor
声明游标,创建一个命名的查询语句
2
Open
打开游标
3
Fetch
取出游标中的一条记录装入变量
4
Close
释放游标
2,当然游标中可以存放一条数据,也可以存放多条数据,后者是我们用游标,前者我们通过PL/SQL语句即可完成的,这样我们在这里就必须用到循环结构了,在Oracle数据库中我们可以使用while…… loop……end loop , for…… loop……end loop,loop……end loop。在这里需要提出的是,for循环结构在Oracle中被简化了,我们只需要声明和使用即可。看下边这个例子吧: